何时使用SET和SELECT为变量赋值
来源:互联网 发布:促销软件 编辑:程序博客网 时间:2024/05/21 17:51
我们经常使用SET和SELECT来为变量复制,但是有时候,只能选其一来使用,下面来看看这些例子,本例中使用AdventureWorks数据库来做演示。
通过查询返回值:
当你把查询返回的值付给变量时,SET将会接受这个结果(单值)并付给一个标量值。但是SELECT 可以接受查询返回的多个值。
下面来看看单值和多值均使用SET的例子:
USE AdventureWorksGO-- 返回一行时使用SETDECLARE @Var1ForSet varchar(50)SET @Var1ForSet = (SELECT [Name] FROM Production.Product WHERE ProductNumber = 'HY-1023-70')PRINT @Var1ForSetGOUSE AdventureWorksGO-- 返回多行时使用SETDECLARE @Var2ForSet varchar(50)SET @Var2ForSet = (SELECT [Name] FROM Production.Product WHERE Color = 'Silver')PRINT @Var2ForSetGO
可以看到如下结果:
当使用SET作为多值赋值时,将会报错。因为SET拒绝一个模糊的值(SET不知道应该用哪个值来赋值)。
下面来看看用SELECT来赋值的例子:
USE AdventureWorksGO-- 通过SELECT 来单值赋值DECLARE @Var1ForSelect varchar(50)SET @Var1ForSelect = (SELECT [Name] FROM Production.Product WHERE ProductNumber = 'HY-1023-70')PRINT @Var1ForSelectGO-- 通过SELECT 来多值赋值DECLARE @Var2ForSelect varchar(50)SELECT @Var2ForSelect = [Name] FROM Production.Product WHERE Color = 'Silver'PRINT @Var2ForSelectGO
可以看到均执行成功。
上面演示的例子,平时可以用作检查问题之用。通过SET来跟踪一些错误。
对多个变量赋予多个值:
当需要赋予多个变量值时,使用SELECT 从一个查询中获取数据是首选。因为可以直接赋值,而不用每次都写SET。可以看看下面的例子:
USE AdventureWorksGO-- 直接赋值DECLARE @var1 VARCHAR(50)DECLARE @var2 VARCHAR(50)DECLARE @var3 VARCHAR(50)SELECT @var1 = 'Value1', @var2 = 'Value2', @var3 = 'Value3'PRINT @var1PRINT @var2PRINT @var3GO-- 通过查询方式赋值DECLARE @name VARCHAR(50)DECLARE @productNo VARCHAR(25)DECLARE @color VARCHAR(15)SELECT @name = [Name], @productNo = ProductNumber, @color = ColorFROM Production.Product WHERE ProductID = 320PRINT @namePRINT @productNoPRINT @colorGO
得到以下结果:
如果需要使用SET,那必须使用多个单独的语句来实现:
USE AdventureWorksGO-- 直接赋值DECLARE @var1 VARCHAR(50)DECLARE @var2 VARCHAR(50)DECLARE @var3 VARCHAR(50)SET @var1 = 'Value1'SET @var2 = 'Value2'SET @var3 = 'Value3'PRINT @var1PRINT @var2PRINT @var3 GO-- 通过查询来赋值DECLARE @name VARCHAR(50)DECLARE @productNo VARCHAR(25)DECLARE @color VARCHAR(15)SET @name =(SELECT [Name] FROM Production.Product WHERE ProductID = 320)SET @productNo = (SELECT ProductNumber FROM Production.Product WHERE ProductID = 320)SET @color = (SELECT Color FROM Production.Product WHERE ProductID = 320)PRINT @namePRINT @productNoPRINT @colorGO
得到结果:
通过对比可以明显看出SELECT 在多值赋值的情况下简便很多,并且也高效,因为一次性实现。
当赋值失败时会如何?
当赋值失败时,SET和SELECT 的行为是不一样的。这里的赋值失败可能是没有数据或者数据类型不配等。此时SELECT会返回上一个值(如果上一个值已经赋值成功),而SET会把NULL赋值给变量。不管如何,这种失败的赋值都会产生不可预计的结果,所以需要细心处理。
下面来看看例子:
USE AdventureWorksGO -- 展示SET赋值失败的情景DECLARE @var1 VARCHAR(20)SET @var1 = 'Value 1 Assigned'PRINT @var1SET @var1 = (SELECT Color FROM Production.Product WHERE ProductID = 32022)PRINT @var1GO-- 展示SELECT赋值失败的情景DECLARE @var1 VARCHAR(20)SELECT @var1 = 'Value 1 Assigned'PRINT @var1 SELECT @var1 = Color FROM Production.Product WHERE ProductID = 32023PRINT @var1GO
结果如下:
从结果中可以看出当SET失败时,返回NULL,而SELECT失败时会返回上一个结果。
标准:
很多时候,使用SELECT是一个不错的选择,但是用SELECT来赋值并不符合ANSI标准,所以如果要遵循标准(可能因为要移植代码到别的DBMS),应该使用SET来替代SELECT 。
总结:
其实最好的方法还是通过实践来证明。很多时候的确可以混用,但是有些时候还是建议单独使用:
使用SET的情景:
- 需要直接赋值,且不需要任何查询,比如变量初始化。
- 故意赋予NULL值。
- 为了将来的移植而遵循ANSI标准。
- 赋予非标量值。
使用SELECT的情景:
- 直接赋予多值变量。
- 通过查询来赋予变量(单值或多值均可)。
- 检查编码量。
- 为了获取变量如@@ROWCOUNT和@@ERROR的值。
- 何时使用SET和SELECT为变量赋值
- 使用Select和Set给变量赋值
- [MSSQL]将查询结果赋值给变量时使用set与select的区别
- 将查询结果赋值给变量时使用set与select的区别
- SQL赋值SET和SELECT的区别
- VBA中给变量赋值使用set和不使用set的区别
- SELECT 与 SET 对变量赋值的区别
- SELECT 与 SET 对变量赋值的区别
- SELECT 与 SET 对变量赋值的区别
- 存储过程中SELECT与SET对变量赋值
- 存储过程中SELECT与SET对变量赋值
- SELECT 与 SET 对变量赋值的区别
- 存储过程中SELECT与SET对变量赋值
- 存储过程中SELECT与SET对变量赋值
- 存储过程中SELECT与SET对变量赋值
- SQL Server中SET赋值和SELECT赋值的区别
- MySQL存储过程中使用SELECT …INTO语句为变量赋值(转)
- mysql存储过程使用select ... into语句为变量赋值范例
- Linux下USB设备检测 .
- C# 导出 Excel 和相关打印设置
- Linux下makefile教程
- C#打印程序实现完整文档打印功能
- linux下面如何设置SSH服务开机启动?
- 何时使用SET和SELECT为变量赋值
- 网易评论真搞笑~~~呵呵
- LINUX如何开启22好端口
- u-boot-1.1.6的配置编译过程分析.doc
- ssh免输入密码登录——ssh-agent完全解析
- u-boot-2012.04.01的配置编译过程分析.doc
- Openstack词汇表查询
- 2012年年度总结
- linux C 遍历目录及其子目录 opendir -> readdir -> closedir