Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Update table set= where - MySQL не работает

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
dp_cmb



Зарегистрирован: 25.12.2006
Сообщения: 1

СообщениеДобавлено: Пн Дек 25 2006 14:14    Заголовок сообщения: Update table set= where - MySQL не работает Ответить с цитатой

Люди помогите, все голову сломал, не работает след update:

update disaload set susp='y' where num=(select disaload.num from disaload,disasusp where disaload.num=disasusp.num);

пишет след. ошибку:

ERROR 1064: You have an error in your SQL syntax near 'select disaload.num from disaload,disasusp where disaload.num=disasusp.num)' at line 1
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
mad_alexx



Зарегистрирован: 14.01.2005
Сообщения: 154
Откуда: Иркутск

СообщениеДобавлено: Пн Дек 25 2006 15:01    Заголовок сообщения: Ответить с цитатой

В одном запросе нельзя читать и обновлять данные одной таблицы. Нужно либо выполнять последовательно два запроса, либо создать временную таблицу копированием существующей и выбирать данные уже из неё
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Alex_pm



Зарегистрирован: 26.08.2006
Сообщения: 55

СообщениеДобавлено: Пт Дек 29 2006 01:10    Заголовок сообщения: Ответить с цитатой

Если я правильно понял, тебе нужно такое:

update disaload set susp='y' where EXISTS(select * from disasusp where disaload.num=disasusp.num);
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
kirchatykh



Зарегистрирован: 19.01.2007
Сообщения: 8

СообщениеДобавлено: Пт Янв 19 2007 16:50    Заголовок сообщения: Ответить с цитатой

мне кажется оператор IN тоже подойдёт (так же как и EXIST)
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
критикан



Зарегистрирован: 18.02.2005
Сообщения: 247

СообщениеДобавлено: Сб Янв 20 2007 19:40    Заголовок сообщения: Ответить с цитатой

mad_alexx писал(а):
В одном запросе нельзя читать и обновлять данные одной таблицы. Нужно либо выполнять последовательно два запроса, либо создать временную таблицу копированием существующей и выбирать данные уже из неё

Вообще-то, это зависит от компилятора СУБД. Если компилятор использует алгоритм, при котором сначала определяется список обновляемых записей с обновляемыми значениями (либо это компилятору можно подсказать), тогда можно. В частности, в MSSQL заданную задачу можно решить так:

Код:
update DL set susp='y' from disasusp as DL inner join disasusp on DL.num=disasusp.num


-------------

kirchatykh писал(а):
мне кажется оператор IN тоже подойдёт (так же как и EXIST)

Решение Alex_pm'а правильное (и самое естественное), а поправка kirchatykh нет.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Suslov



Зарегистрирован: 08.03.2006
Сообщения: 67

СообщениеДобавлено: Чт Мар 08 2007 01:31    Заголовок сообщения: Ответить с цитатой

Ну и как удалось решить? По-моему в my не работает соединение таблиц и запрос в запросе или не так?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...