转自 : http://www.cnblogs.com/4mylife/archive/2012/10/25/2738466.html

下表列出 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

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初始值
GO

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

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

最新文章

  1. 【Beta】第四次任务发布
  2. JVM相关参数的采集
  3. 判断.NET4.0是否安装
  4. Clough-Tocher
  5. Lucene教程--转载
  6. 高性能网络I/O框架-netmap源码分析
  7. [C入门 - 游戏编程系列] 贪吃蛇篇(二) - 食物定义
  8. jar文件につぃて
  9. SignalR的实时高频通讯
  10. SQL点滴17—使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识
  11. java注解--Annotation
  12. oracle数据库 查看被锁定表及解锁方法
  13. RabbitMQ和kafka从几个角度简单的对比
  14. linux文件权限目录配置笔记
  15. RbbitMQ 的 python 实现方法
  16. APP微信支付报错《商户号该产品权限未开通,请前往商户平台&gt;产品中心检查后重试》
  17. strstr函数字符串匹配问题
  18. SHOI2016方
  19. 虚拟机内存复用技术的比较(XEN系统)
  20. kafka集群监控工具之三--kafka Offset Monitor

热门文章

  1. JSP--TOMCAT-MYSQL web页面查询
  2. C语言基础:结构体 分类: iOS学习 c语言基础 2015-06-10 21:47 28人阅读 评论(0) 收藏
  3. Linux C socket 封装
  4. linux-锁屏时间设置
  5. pymysql模块操作数据库
  6. 练习SQL代码
  7. es6语法快速上手(转载)
  8. scanner 在java中的输入
  9. binlog cache size设置是否合理判断
  10. Windows 上 Nginx 路径的陷阱