SQL中select与set的区别-转载

Posted hao_1234_1234

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL中select与set的区别-转载相关的知识,希望对你有一定的参考价值。

下表列出 SET 与 SELECT 的区别

  SELECT SET
同时对多个变量同时赋值 支持 不支持
表达式返回多个值时 将返回的最后一个值赋给变量 出错
表达式未返回值时 变量保持原值 变量被赋null值

(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

来源 http://www.cnblogs.com/4mylife/archive/2012/10/25/2738466.html

 

 

以上是关于SQL中select与set的区别-转载的主要内容,如果未能解决你的问题,请参考以下文章

sql server存储过程中SELECT 与 SET 对变量赋值的区别

sql 中set和select区别

Sql中的set和select赋值方式的区别

sql server set赋值和select 赋值的区别以及使用方法

sql server select和set赋值的区别

通过set赋值,与select赋值的区别