下表列出 SET 与 SELECT 的区别
(1).同时对多个变量同时赋值时 declare @a varchar(128), @b varchar(128) SET @a='ABC',@b='EFG' GO --报错:消息 102,级别 15,状态 1,第 3 行 ',' 附近有语法错误。 declare @a varchar(128), @b varchar(128) SELECT @a='ABC',@b='EFG' GO --正确运行 (2).表达式返回多个值时 在说明这一项前我们先创建一个要用到的表,并对其赋值,代码如下:
create table fuzhiTEST(
id int ,
name varchar(128)
)
go
insert into fuzhiTEST(id,name) values(1,'name1')
insert into fuzhiTEST(id,name) values(2,'name2')
insert into fuzhiTEST(id,name) values(3,'name3')
go
declare @name varchar(128) set @name = (select name from fuzhiTEST) GO --报错:消息 512,级别 16,状态 1,第 2 行 子查询返回的值不止一个。当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。 declare @name varchar(128) select @name =name from fuzhiTEST print @name GO --正确运行:显示 name3 (3).表达式未返回值时 declare @name varchar(128) set @name = 'SET初始值' set @name = (select name from fuzhiTEST where id = 4 ) print @name GO --正确运行:显示NULL declare @name varchar(128) set @name = 'SELECT初始值' select @name = name from fuzhiTEST where id = 4 print @name --正确运行:显示SELECT初始值 注意:SELECT 也可以将标量子查询的值赋给变量,如果标量子查询不返回值,则变量被置为 null 值(此时与使用 SET 赋值是完全相同的)。 对标量子查询的概念大家可能觉得陌生,下面举个例子说明下(对比上面绿色部分): declare @name varchar(128) set @name = 'SELECT初始值' select @name =(select name from fuzhiTEST where id = 4 ) print @name --正确运行:显示NULL (责任编辑:IT) |