【SQL Server】变量的使用

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

变量的分类

局部变量:(仅在过程中使用)
局部变量必须标记@作为前缀,如@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比较

使用场景setselect
同时对多个变量赋值不支持支持
表达式返回多个值时出错将返回的最后一个值赋给变量
表达式未返回值时变量被赋NULL值变量保持原值

全局变量的使用

变量含义
@@ERROR最后一个T-SQL错误的错误号
@@IDEENTITY最后一次插入的标识值
@@LANGUAGE当前使用的语言的名称
@@MAX_CONNECTIONS可以创建的同时连接的最大数目
@@ROWCOUNT受上一个SQL语句影响的行数
@@SERVERNAME本地服务器的名称
@@TRANSCOUNT当前连接打开的事务数
@@VERSIONSQLServer的版本信息
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

code-Study

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值