数据库用户能否建立全局变量

数据库用户能否建立全局变量,第1张

是的,数据库用户可以建立全局变量全局变量是一组用户定义的标量变量,可以在整个数据库中使用,也就是说,在任何一个会话中定义的全局变量都可以在任何会话中使用。这些变量可以保存字符串、数字或者二进制数据等,并且可以在存储过程中使用。创建全局变量的语法如下:SET GLOBAL <变量名>= <值>;另外,全局变量可以用来控制特定的数据库行为,比如用来确定一个数据库的查询是否启用索引,以及查询是否应该使用缓存等。

局部变量是用户可自定义的变量,它的作用范围仅在程序内部。在程序中通常用来储存从表中查询到的数据,或当作程序执行过程中暂存变量使用。局部变量必须以“@”开头,而且必须先用DECLARE命令说明后才可使用。其说明形式如下:

DECLARE @变量名 变量类型 [@变量名 变量类型…]

其中变量类型可以是sql server(WINDOWS平台上强大的数据库平台) 2000支持的所有数据类型,也可以是用户自定义的数据类型。 

在Transact-SQL中不能像在一般的程序语言中一样使用“变量=变量值”来给变量赋值。必须使用SELECT或SET命令来设定变量的值,其语法如下:

SELECT @局部变量=变量值

SET @局部变量=变量值1212

例:声明一个长度为10 个字符的变量“id”并赋值

declare @id char(10)

select @id=‘10010001’1212

注意:可以在Select命令查询数据时,在Select命令中直接将列值赋给变量。 

例:查询编号为“10010001”的员工和工资,将其分别赋予变量name和wage

use pangu

declare @name char(30)@wage money

select @name=e_name,@wage=e_wage

from employee

where emp_id='10010001'

select @name as e_name,@wage as e_wage123456123456

运行结果如下:

e_name e_wage

------------------------------ -----------

张三 8000.0000123123

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

全局变量

全局变量是sql server(WINDOWS平台上强大的数据库平台)系统内部使用的变量,其作用范围并不局限于某一程序,而是任何程序均可随时调用全局变量通常存储一些sql server(WINDOWS平台上强大的数据库平台)的配置设定值和效能统计数据。用户可在程序中用全局变量来测试系统的设定值或Transact-SQL命令执行后的状态值。有关sql server(WINDOWS平台上强大的数据库平台) 全局变量的详细情况请参见附录。 

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


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/11144103.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-13
下一篇2023-05-13

发表评论

登录后才能评论

评论列表(0条)

    保存