sql insert语句中如何使用变量
Msg 137, Level 15, State 2, Line 67
Must declare the scalar variable "@".
我的语句是这样的:
INSERT INTO [BTS].[dbo].[Main_Test_Info] ([Test_Type],[SN_AN],[SN_ACU],[Operator],
[Test_Status],[Test_Time],[Test_Station],
[Test_Machine],[SW_Version],[Duration],
[Fail_Item],[Product_Code])
Values(@Test_Type,@SN_AN,@[SN_ACU],@[Operator],
@Test_Status,@Test_Time,@Test_Station,
@Test_Machine,@SW_Version,@Duration,
@Fail_Item,@Product_Code)
是不是要在values里的变量加引号什么的?? 展开
sql insert语句中使用变量:
(insert)向表中添加一个新记录,要使用SQL INSERT 语句。这里有一个如何使用这种语句的例子: INSERT mytable (mycolumn) VALUES (‘some data') 这个语句把字符串'some data'插入表mytable的mycolumn字段中。将要被插入数据的字段的名字在第一个括号中指定,实际的数据在第二个括号中给出。
INSERT 语句的完整句法如下:INSERT [INTO] {table_name|view_name} [(column_list)] {DEFAULT VALUES |
Values_list | select_statement}
如果一个表有多个字段,通过把字段名和字段值用逗号隔开,可以向所有的字段中插入数据。假设表mytable有三个字段first_column,second_column,和third_column.下面的INSERT语句添加了一条三个字段都有值的完整记录:INSERT mytable (first_column,second_column,third_column)
VALUES (‘some data','some more data','yet more data')
可以使用INSERT语句向文本型字段中插入数据。但是,如果需要输入很长的字符串,应该使用WRITETEXT语句。
如果在INSERT 语句中只指定两个字段和数据。向一个表中插入一条新记录,但有一个字段没有提供数据。在这种情况下,有下面的四种可能:
1)如果该字段有一个缺省值,该值会被使用。例如,假设插入新记录时没有给字段third_column提供数据,而这个字段有一个缺省值'some value'.在这种情况下,当新记录建立时会插入值'some value'。
2)如果该字段可以接受空值,而且没有缺省值,则会被插入空值。
3)如果该字段不能接受空值,而且没有缺省值,就会出现错误。会收到错误信息:The column in table mytable may not be null.
4)最后,如果该字段是一个标识字段,那么它会自动产生一个新值。当向一个有标识字段的表中插入新记录时,只要忽略该字段,标识字段会给自己赋一个新值。
注:向一个有标识字段的表中插入新记录后,可以用SQL变量@@identity来访问新记录 的标识字段的值。考虑如下的SQL语句:
INSERT mytable (first_column) VALUES(‘some value')
INSERT anothertable(another_first,another_second)
VALUES(@@identity,'some value')
如果表mytable有一个标识字段,该字段的值会被插入表anothertable的another_first字段。这是因为变量@@identity总是保存最后一次插入标识字段的值。
字段another_first应该与字段first_column有相同的数据类型。但是,字段another_first不能是应该标识字段。Another_first字段用来保存字段first_column的值。
用游标的自动赋值了。我就是想在insert语句里使用变量,不然赋值几百条数据如要让人崩溃呀!
我明白了,使用变量的话,建议你使用concat(,);方法,把sql语句和变量连起来,再执行,如果是字符类型的话,是需要加引号!(这个得看你的变量中有没有引号,如果有的话就不需要再加了)
这里的变量@[SN_ACU],@[Operator]不要加中括号@SN_ACU,@Operator