Transact-SQL中的局部变量和全局变量

Transact-SQL局部变量和全局变量 数据库

Transact-SQL中可使用两种变量,一种是局部变量(Local Variable)另一种是全局变量(Global Variable)。

局部变量
局部变量是用户可自定义的变量,它的做用范围仅在程序内部。在程序中一般用来储存从表中查询到的数据,或看成程序执行过程当中暂存变量使用。局部变量必须以“@”开头,并且必须先用DECLARE命令说明后才可以使用。其说明形式以下:
DECLARE @变量名变量类型[@变量名变量类型…]
其中变量类型能够是SQL Server 2000支持的全部数据类型,也能够是用户自定义的数据类型。
在Transact-SQL中不能像在通常的程序语言中同样使用“变量=变量值”来给变量赋值。必须使用SELECT或SET命令来设定变量的值,其语法以下:
SELECT@局部变量=变量值
SET @局部变量=变量值
例:声明一个长度为10个字符的变量“id”并赋值
declare @id char(10)
select @id=‘10010001’ 编程

注意:能够在Select命令查询数据时,在Select命令中直接将列值赋给变量。例1:查询座位号为“3”的学员和年龄,将其分别赋予变量name和age。 服务器

例1
usestuDB 编程语言

declare@namevarchar(8)  测试

declare@ageint rest

select@name=stuName,@age=stuAgefromstuInfowherestuSeat=3 对象

select@nameas 姓名,@ageas 年龄
运行结果以下:
姓名      年龄 变量

-------- ----------- 配置

李文才     31 select

注意:数据库语言和编程语言有一些关键字,关键字是在某一同样下可以促使某一操做发生的字符组合,为避免冲突和产生错误,在命令表、列、变量以及其它对象时应避免使用关键字。

全局变量
全 局变量是SQL Server系统内部使用的变量,其做用范围并不局限于某一程序,而是任何程序都可随时调用全局变量一般存储一些SQL Server的配置设定值和效能统计数据。用户可在程序中用全局变量来测试系统的设定值或Transact-SQL命令执行后的状态值。有关SQL Server全局变量的详细状况请参见附录。

注意:全局变量不是由用户的程序定义的,它们是在服务器级定应义的。只能使用预先说明及定义的变局变量。引用全局变量时,必须以“@@”开头。局部变量的名称不能与全局变量的名称相同、不然会在应用中出错。

相关文章
相关标签/搜索