Оператор SQL Update - синтаксическая ошибка рядом с "SET"? - PullRequest
3 голосов
/ 06 сентября 2011

Я генерирую приведенный ниже оператор sql на основе некоторой логики Coldfusion, но он ошибочен, и я не могу найти причину, я попытался внести в него много разных модификаций, и, похоже, ничего не помогает.

UPDATE MAIN_RECORDS 
SET JONUM = NULL, 
SET CUSTNAME = 'Super Sweet Name', 
SET CONTACTDT = 02/28/2011, 
SET ENGRECDT = 03/07/2011, 
SET HOW_WR_DT = 03/07/2011, 
SET COMM_DT = 03/29/2011, 
SET FACAVALDT = NULL, 
SET FAX_SUPDT = 03/07/2011, 
SET LINENUM = 'CLPRO L6', 
SET POLENUM = 'CLPRO 125 T T3', 
SET REASON = '03/07/11 NO VAC FAC THIS IS THE WRONG INFORMATION IT WAS ON HERE TWICE', 
SET REC_TYPE = 'H', 
SET ORDER_TYPE = 'P', 
SET CANCEL_ORDER = 'Y', 
SET State_abbr = 'IL', 
SET dbfk_state = 17, 
SET xx_streetnumber = '2626', 
SET xx_street = 'Fake St', 
SET xx_city = 'NEWTON', 
SET xx_class_of_service_ind = 'R', 
SET xx_cellphone_ind = '1', 
SET xx_assigned_phone = '3045653897', 
SET xx_exchange_name = 'NEWTON', 
SET XX_new_ref_code = '60', 
SET xx_new_service_type = '11', 
SET ORD_COMDT = 03/11/2011, 
SET delivery_date = NULL 
WHERE ordernum = '08824112' AND exchnum = '304565' 

В настоящее время ошибка, которую дает мне студия управления:

Msg 156, Level 15, State 1, Line 1
Incorrect syntax near the keyword 'SET'.

Ответы [ 4 ]

11 голосов
/ 06 сентября 2011

Вам нужно только 1 SET заявление вместо нескольких ваших.

Кроме того, ваши даты должны заключаться в одинарные кавычки.

Например:

UPDATE MAIN_RECORDS 
SET JONUM = NULL, 
    CUSTNAME = 'Super Sweet Name', 
    CONTACTDT = '02/28/2011', 
    ENGRECDT = '03/07/2011', 
    HOW_WR_DT = '03/07/2011', .....
5 голосов
/ 06 сентября 2011

Посмотрите на оператор UPDATE . Синтаксис в посте все неверный:)

Соответствующая часть:

SET
        { column_name = { expression | DEFAULT | NULL }
        | @variable = expression
        | @variable = column = expression } [ ,...n ] 

Обратите внимание, что SET можно указать только один раз . ,...n означает, что предыдущее потребление (которое в {}) может быть указано дополнительно n раз, разделенных запятой: само ключевое слово SET, однако, находится за пределами этой конструкции.

Удачного кодирования.

3 голосов
/ 06 сентября 2011

Ну, как правило, синтаксис команды для этого будет следовать этой логике

UPDATE table_name
 SET column1=value, column2=value2,...
 WHERE some_column=some_value

, поэтому только один SET не кратен тому, который у вас есть

0 голосов
/ 19 июля 2013

Для обновления n ключевых слов требуется только один SET, например:

Update Employee 
set City = Chennai,Country ='India',Employee name = 'Vignesh'
where  Employee Id = 1X234
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...