sqlserverselect选择两个参数(SQL SERVER中SELECT和SET赋值相同点与不同点推荐)
类别:数据库 浏览量:1320
时间:2021-10-22 07:26:01 sqlserverselect选择两个参数
SQL SERVER中SELECT和SET赋值相同点与不同点推荐SELECT和SET在SQL SERVER中都可以用来对变量进行赋值,但其用法和效果在一些细节上有些不同。
1. 在对变量赋值方面,SET是ANSI标准的赋值方式,SELECT则不是。这也是SET方式被推荐使用的原因之一。
2. SELECT可以一次对多个变量进行赋值,而SET一次只能对一个变量赋值。
DECLARE @NAME NVARCHAR(128), @AGE INT; SET @NAME = N'小明'; SET @AGE=18; PRINT @NAME; PRINT @AGE; GO DECLARE @NAME NVARCHAR(128), @AGE INT; SELECT @NAME = N'小明',@AGE=18; PRINT @NAME; PRINT @AGE;
3.当使用子查询给变量赋值时,则要求子查询必须是标量子查询(即子查询得到结果是一个数据或者一行一列),不能返回多个值,否则会报错。
1)但要注意的是,如果在SELECT查询语句中给变量赋值的时候,查询语句返回记录的多少都不会产生错误,变量所得的值是查询语句最后一行的记录的相应值。
2)如果查询结果没有返回记录,也就是说返回为NULL值时,将整个子查询进行赋值的方式,SET和SELECT都会设置为NULL,而在SELECT查询语句中赋值,变量会保持为初始值不受影响。
IF (OBJECT_ID('tempdb..#temp') is not null) BEGIN DROP TABLE #temp; END ELSE BEGIN CREATE TABLE #temp( [Name] NVARCHAR(128) , AGE INT ) END GO INSERT INTO #temp([Name],AGE) VALUES(N'小明',18) INSERT INTO #temp([Name],AGE) VALUES(N'小张',19) INSERT INTO #temp([Name],AGE) VALUES(N'小王',17) GO DECLARE @NAME1 NVARCHAR(128), @AGE1 INT,@NAME2 NVARCHAR(128), @AGE2 INT; SET @NAME1=(SELECT TOP 1 [NAME] FROM #temp); --SET标量在查询赋值 SELECT @AGE1=(SELECT TOP 1 AGE FROM #temp); --SELECT标量在查询赋值 SELECT @NAME2=[NAME],@AGE2=[AGE] FROM #temp; --SELECT查询语句中赋值 PRINT @NAME1; --正确运行,显示结果:小明 PRINT @AGE1; --正确运行,显示结果:18 PRINT @NAME2; --正确运行,显示结果:小王 PRINT @AGE2; --正确运行,显示结果:17 GO DECLARE @NAME1 NVARCHAR(128), @AGE1 INT,@NAME2 NVARCHAR(128), @AGE2 INT; SELECT @NAME1=N'初始名字',@AGE1=0,@NAME2=N'初始名字',@AGE2=0; --初始化各变量值 SET @NAME1=(SELECT TOP 1 [NAME] FROM #temp WHERE 1>1); --SET标量在查询赋值 SELECT @AGE1=(SELECT TOP 1 AGE FROM #temp WHERE 1>1); --SELECT标量在查询赋值 SELECT @NAME2=[NAME],@AGE2=[AGE] FROM #temp WHERE 1>1; --SELECT查询语句中赋值 PRINT @NAME1; --正确运行,实际值:NULL, 显示结果:(空白) PRINT @AGE1; --正确运行,实际值:NULL, 显示结果:(空白) PRINT @NAME2; --正确运行,实际和显示值:初始名字 PRINT @AGE2; --正确运行,实际和显示值:0 GO
那么我们该如何选择使用哪种方式:
1. 因SET作为ANSI的标准,因此其是推荐用法。
2. 在不考虑标准的情况下,如果涉及到对多个变量赋值,为了少写代码或者获取多个全局变量的值时,请考虑使用SELECT,一是因为简便,二是一些全局变量会在在第二句执行时值发生变化。
总结
以上所述是小编给大家介绍的SQL SERVER中SELECT和SET赋值相同点与不同点,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对开心学习网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
您可能感兴趣
- mysql中数据类型的学习体会(MySQL 实现lastInfdexOf的功能案例)
- mysql事务特性和隔离级别(Mysql事务特性和级别原理解析)
- mysql数据类型及用法(MySQL数据库重命名的快速且安全方法3种)
- mysql意外查不到数据(MySQL 丢失数据的原因及解决)
- SQL SERVER连接池
- mysql统计下个月过生日的人数(Mysql出生日期转换为年龄并分组统计人数的方法示例)
- sqlserver基础数据类型(SQL Server中T-SQL 数据类型转换详解)
- mysql binlog模式实际使用(实例验证MySQL|update字段为相同的值是否会记录binlog)
- sql server建表语句带字段说明(SqlServer给表增加多个字段的语法)
- mysql查看执行慢的sql(系统隐形杀手——阻塞与等待SQL)
- sql查询语句casewhen是什么意思(SQL Server中使用判断语句IF ELSE/CASE WHEN 案例)
- mysql数据库使用规则(mysql数据库基本语法及操作大全)
- sqlserver2012登录出现报错18456(SQL Server 2012 sa用户登录错误18456的解决方法)
- mysql怎么迁移数据(如何把本地mysql迁移到服务器数据库)
- phpstudy的mysql无法启动(Windows系统下解决PhPStudy MySQL启动失败问题)
- mysql演示事务提交(MySQL找出未提交事务的SQL实例浅析)
- 九月初,爱如蜜糖,甜到心扉,迷恋彼此,一日不见兮,思之若狂(九月初爱如蜜糖)
- ()
- 对你思念入骨的女人,跟你见面时会有这几种表现,藏都藏不住(对你思念入骨的女人)
- 纳兰性德绝美作,一场重逢,成就最后一首称得上惊艳的《如梦令》(纳兰性德绝美作)
- 如何快速赚钱(如何快速赚钱方法真实有效)
- 这里输入关键词(如何输入关键词)
热门推荐
- mysql常见的存储引擎(如何选择MySQL的存储引擎?)
- 织梦dedecms当前栏目页面样式(织梦dedecms二次开发之install安装改动攻略)
- php怎样创建新文件详情(php文件后缀不强制为.php的实操方法)
- Visual studio中使用VSCommands插件在大括号尾部显示方法或过程名字
- 数组reduce方法的好处(JS使用reduce方法处理树形结构数据)
- sqlserver2016安装教程(SQL server 2016 安装步骤图文教程)
- docker的漏洞(一次docker错误的耗时排查过程记录)
- javascript变量值做函数名(JavaScript中变量提升和函数提升实例详解)
- python抖音视频收集(python制作抖音代码舞)
- 查看SQL SERVER中某个查询用了多少TempDB空间
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9