局部变量:(仅在过程中使用) 局部变量必须标记@作为前缀,如@age。 局部变量的使用也是先声明(使用declare),再赋值。 全局变量:(任何时候均可以使用) 全局变量必须以标记@@作为前缀,如@@version. 全局变量由系统定义和维护,我们只能读取,不能修改全局变量值。
局部变量的定义语法 DECLARE @变量名 数据类型 赋值方法 SET @变量名 = 值 或 SELECT @变量名 = 值
使用select赋值确保筛选出的记录只有一条
下面以一个场景来使用定义变量,有如下的一个表结构,表名称为Students,现在要查询李铭及其学号相邻的学员。
use StudentManageDB
go
declare @stuid int,@stuname varchar(20)
--查询李铭的信息
set @stuname = '李铭'
select StudentId,StudentName,Gender,StudentIdNo from Students
where StudentName = @stuname
--查询李铭的学号
select @stuid =StudentId from Students where StudentName = @stuname
--查询与李铭学号相邻的学员
select StudentId,StudentName,Gender,StudentIdNo from Students
where StudentId =(@stuid+1) or StudentId=(@stuid-1)
查询结果
使用场景 | set | select |
---|---|---|
同时对多个变量赋值 | 不支持 | 支持 |
表达式返回多个值时 | 出错 | 将返回的最后一个值赋给变量 |
表达式未返回值时 | 变量被赋NULL值 | 变量保持原值 |
变量 | 含义 |
---|---|
@@ERROR | 最后一个T-SQL错误的错误号 |
@@IDEENTITY | 最后一次插入的标识值 |
@@LANGUAGE | 当前使用的语言的名称 |
@@MAX_CONNECTIONS | 可以创建的同时连接的最大数目 |
@@ROWCOUNT | 受上一个SQL语句影响的行数 |
@@SERVERNAME | 本地服务器的名称 |
@@TRANSCOUNT | 当前连接打开的事务数 |
@@VERSION | SQLServer的版本信息 |