【SQL Server】变量的使用

变量的分类

局部变量:(仅在过程中使用)
局部变量必须标记@作为前缀,如@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的版本信息
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Maybe_ch

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

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

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

打赏作者

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

抵扣说明:

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

余额充值