变量的分类
局部变量:(仅在过程中使用)
局部变量必须标记@作为前缀,如@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比较
| 使用场景 | set | select |
|---|---|---|
| 同时对多个变量赋值 | 不支持 | 支持 |
| 表达式返回多个值时 | 出错 | 将返回的最后一个值赋给变量 |
| 表达式未返回值时 | 变量被赋NULL值 | 变量保持原值 |
全局变量的使用
| 变量 | 含义 |
|---|---|
| @@ERROR | 最后一个T-SQL错误的错误号 |
| @@IDEENTITY | 最后一次插入的标识值 |
| @@LANGUAGE | 当前使用的语言的名称 |
| @@MAX_CONNECTIONS | 可以创建的同时连接的最大数目 |
| @@ROWCOUNT | 受上一个SQL语句影响的行数 |
| @@SERVERNAME | 本地服务器的名称 |
| @@TRANSCOUNT | 当前连接打开的事务数 |
| @@VERSION | SQLServer的版本信息 |

本文介绍了SQL中局部变量和全局变量的定义与使用方法,包括声明、赋值等操作,并通过具体场景展示了变量的应用过程。此外,还列举了多种常用的全局变量及其含义。
1290

被折叠的 条评论
为什么被折叠?



