SQL SERVER中SELECT和SET赋值相同点与不同点(推荐)
网络编程 2021-07-05 13:43www.168986.cn编程入门
SELECT和SET在SQL SERVER中都可以用来对变量进行赋值,但其用法和效果在一些细节上有些不同。今天长沙网络推广给大家分享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赋值相同点与不同点,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
如果你觉得本文对你有帮助,欢迎网络推广网站推广转载,烦请注明出处,谢谢!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程