SQL中select与set的区别

您所在的位置:网站首页 selection与choice的区别 SQL中select与set的区别

SQL中select与set的区别

2024-07-15 15:40| 来源: 网络整理| 查看: 265

下表列出 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).表达式返回多个值时

在说明这一项前我们先创建一个要用到的表,并对其赋值,代码如下:

 

赋值测试表--fuzhiTEST 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 fuzhiTESTprint @nameGO  --正确运行:显示 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初始值GO

注意:SELECT 也可以将标量子查询的值赋给变量,如果标量子查询不返回值,则变量被置为 null 值(此时与使用 SET 赋值是完全相同的)。 对标量子查询的概念大家可能觉得陌生,下面举个例子说明下(对比上面绿色部分):

declare @name varchar(128)set @name = 'SELECT初始值'select @name =(select name from fuzhiTEST where id = 4 )print @name --正确运行:显示NULLGO



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3