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常用的sql语句大全(mysql建表常用的sql语句汇总)
- phpmysql网站开发入门与提高(PHP+MySQL+sphinx+scws实现全文检索功能详解)
- sqlserver恢复delete数据(SQL Server数据库的三种恢复模式:简单恢复模式、完整恢复模式和大容量日志恢)
- sqlserver2012tcpip配置(Sql Server2012 使用IP地址登录服务器的配置图文教程)
- sqlserver自增长id重置(SQL server 自增ID--序号自动增加的字段操作)
- sqlserver数字格式化五位小数(详细分析sqlserver中的小数类型float和decimal)
- 终于有人将mysql 索引讲清楚了(MySQL 索引的一些细节分享)
- 如何重新配置mysql的端口(如何快速修改MySQL用户的host属性)
- sql server优化性能(SQLServer地址搜索性能优化)
- mysql怎么解决幻读问题(详解MySQL幻读及如何消除)
- mysql完整教程(MySql新手入门的基本操作汇总)
- mysql模糊匹配语句(MySQL 数据库 like 语句通配符模糊查询小结)
- centos7怎么安装mysql(Centos7 mysql数据库安装及配置实现教程)
- mysql如何删除外键约束数据(MySQL中外键的创建、约束以及删除)
- mysql怎么设置某个字段默认值(MySQL表字段时间设置默认值)
- mysql快速创建索引(MySQL创建高性能索引的全步骤)
- 华为 联想等46家公司笔试面试题,涉及各行各业,建议收藏(联想等46家公司笔试面试题)
- ()
- ()
- 800壮士拼死拖住30万日军 八佰 的真实历史,誓与阵地共存亡(800壮士拼死拖住30万日军)
- 演员陈创,火于 哮天犬 ,颠峰于 福贵 ,现状却令人唏嘘(演员陈创火于哮天犬)
- 幼小衔接-20以内看图读数 写数 数的组成练习题(幼小衔接-20以内看图读数)
热门推荐
- 阿里云ecs部门怎么样(阿里云ecs是什么意思?)
- css下填充代码(CSS学习笔记之常用Mixin封装实例代码)
- css怎么给背景颜色设置模糊(CSS设置背景图片模糊内容不模糊的解决方法)
- docker redis配置文件放哪里(最详细的docker中安装并配置redis图文详解)
- laravel查询限制输出设置(laravel validate 设置为中文的例子验证提示为中文)
- vue如何获取元素(vue第一次获取不到元素的解决方法记录)
- php开发模式有哪些(PHP设计模式之简单工厂和工厂模式实例分析)
- sqlserver表值函数用法(SQL Server数据库中的表名称、字段比较)
- 自己在做项目过程中的php知识(PHP+Oracle本地开发环境搭建方法详解)
- nginx怎么配置静态资源(nginx实现发布静态资源的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9