T-SQL语句如何使用变量,变量的种类是什么
Admin 2022-08-04 群英技术资讯 836 次浏览
关于“T-SQL语句如何使用变量,变量的种类是什么”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友就继续往下看吧。在T-SQL中,变量按生存范围可以分为全局变量(Global Variable)和局部变量(Local Variable)
示例:
DECLARE @i int --声明一个int类型局部变量 SET @i = 10 --通过SET对局部变量进行赋值 DECLARE @Name nvarchar(20) --声明一个nvarchar(20)类型变量 SET @Name = '张飞' PRINT @@VERSION --全部变量,只能读取,不能赋值 SET @@VERSION = '123' --此行代码报错
select @@CONNECTIONS; --返回自上次SQL启动以来连接或试图连接的次数。 select @@CPU_BUSY / 100; --返回自上次启动SQL 以来 CPU 的工作时间,单位为毫秒 select @@CURSOR_ROWS as w; --返回被打开的游标中还未被读取的有效数据行的行数 select @@DATEFIRST as w; --返回使用SET DATEFIRST 命令而被赋值的DATAFIRST ,用来指定每周的第一天是星期几 select @@FETCH_STATUS as w; --返回上一次FETCH 语句的状态值(0:成功,-1失败或行超过结果集,-2行没找到) select @@DBTS as w; --为当前数据库返回当前 timestamp 数据类型的值。这一 timestamp 值保证在数据库中是唯一的。 select @@ERROR; --返回最后执行的 Transact-SQL 语句的错误代码(integer) (0,表示没错误;1,表示有错误) select @@IDENTITY as w; --返回最后插入的标识值 select @@IDLE as w; --返回SQL自上次启动后闲置的时间,单位为毫秒 select @@IO_BUSY as w; --返回SQL自上次启动后用于执行输入和输出操作的时间,单位为毫秒 select @@LANGID as w; --返回当前所使用语言的本地语言标识符(ID)。 select @@LANGUAGE as w; --返回当前使用的语言名 select @@LOCK_TIMEOUT as w; --当前会话的当前锁超时设置,单位为毫秒。 select @@MAX_CONNECTIONS as w; --返回SQL上允许的同时用户连接的最大数。返回的数不必为当前配置的数值 select @@MAX_PRECISION as w; --返回 decimal 和 numeric 数据类型所用的精度级别,即该服务器中当前设置的精度。默认最大精度38。 select @@OPTIONS as w; --返回当前 SET 选项的信息。 select @@PACK_RECEIVED as w; --返回SQL自启动后从网络上读取的输入数据包数目。 select @@PACK_SENT as w; --返回SQ自上次启动后写到网络上的输出数据包数目。 select @@PACKET_ERRORS as w; --返回自SQL启动后,在SQL连接上发生的网络数据包错误数。 select @@ROWCOUNT as w; --返回上一次语句影响的数据行的行数 select @@SERVERNAME as w; --返回运行SQL服务器名称。 select @@SERVICENAME as w; --返回SQL正在其下运行的注册表键名 select @@TIMETICKS as w; --返回SQL服务器一刻度的微秒数 select @@TOTAL_ERRORS as w; --返回 SQL服务器自启动后,所遇到的磁盘读/写错误数。 select @@TOTAL_READ as w; --返回 SQL服务器自启动后读取磁盘的次数。 select @@TOTAL_WRITE as w; --返回SQL服务器自启动后写入磁盘的次数。 select @@TRANCOUNT as w; --返回当前连接的活动事务数。 select @@VERSION as w; --返回当前安装的SQL Server 的日期版本处理器
局部变量的声明必须以"DECLARE"作为关键字,变量的命名必须以"@"作为变量名的第一个字符,必须为所声明的变量提供一个数据类型和数据长度。
如:
DECLARE @Name nvarchar(20)
注意:局部变量的数据类型不能为Text,ntext,和Image类型,当对于字符型变量只提供数据类型没有提供数据长度时,数据长度默认为1.
有两种设置变量值方法。可以使用SELECE语句或者SET语句。从功能上看,它们的作用几乎是相同的,不同的是SELECT语句允许元数据值来自SELECT语句中的某一列。
DECLARE @i int,@j int set @i = 10; set @j = 20; select @i + @j
用查询到的值设置变量:
DECLARE @i int SET @i = (select MAX(Age) from Person) --当使用SET时如果返回结果有多行也会报错。同时如果返回多条记录也报错 SELECT @i
当变量中存储的信息来源于查询时,经常使用SELECT给变量赋值,语法比较简便。
DECLARE @i int SELECT @i = 100 SELECT @i
查询的信息为变量赋值:
DECLARE @i int SELECT @i = Age from Person_1 order by Id desc --当返回多个值时用最后一个赋值 PRINT @i
SELECT同时设置多个值:
DECLARE @Name varchar(20) DECLARE @i int SELECT @i = 10, @Name = '张飞'
例如:
DECLARE @Name nvarchar(50) SET @Name = '黄飞鸿' select @Name = Name from Person_1 where Id = 100 --100不存在记录,此处如果改为一个Id存在的,且Name列不为null的值,则@Name变量的值就变了 PRINT @Name --依然打印的是黄飞鸿
可见,当SELECT表达式赋值时,如果为返回值,则保持原值。
局部表变量是一个特殊的局部变量。和临时表不同,局部表变量具有一切局部变量的特点。在查询中,因为局部表变量是存在内存中,而不是硬盘中,所以速度会远远快于临时表或是实际表。局部表变量最多的使用是在查询中充当多个表做连接时的中间表。
DECLARE @TempTable TABLE --声明一个局部表变量
(
Id int,
Name nvarchar(50)
)
INSERT INTO @TempTable --用查询到的作为数据插入到局部表变量
SELECT Id,Name FROM Person_1
SELECT * FROM @TempTable --和普通表一样用,可以各种join,子查询等等。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文详细讲解了SQL Server中分区表的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
今天主要给大家分享的是sql数据库错误9003的原因及解决方法,但是要注意的是,以下9003错误解决方法只适用于SQL2000。废话不多,接下来跟随小编一起来看看吧。
一些朋友对于sql附加数据库失败怎么解决不是很清楚,下面小编给大家分享报错341和报错5120两种情况的解决办法,需要的朋友可参考。下面我们就来一起看看。
本文通过几个小例子,给大家分享一下常用SQL常用的语句,非常的简单实用,有需要的小伙伴可以参考下。
本文详细讲解了Sql Server的存储过程,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008