前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL教程:变量

SQL教程:变量

作者头像
SQL数据库开发
发布2024-05-10 18:31:16
890
发布2024-05-10 18:31:16
举报
文章被收录于专栏:SQL数据库开发SQL数据库开发

变量的定义

SQL Server中的变量就是一个参数,可以对这个参数进行赋值。

变量的分类

变量分为局部变量和全局变量,局部变量用@来标识,全局变量用@@来标识(常用的全局变量一般都是已经定义好的)

声明变量

变量在使用前必须先声明才能够使用。

申明局部变量语法

DECLARE @变量名 数据类型;

例如:

代码语言:javascript
复制
DECLARE @A INT;

这样就声明了一个整数型的变量@A

局部变量赋值

声明完了变量就可以给变量赋值了,变量赋值有两种方式SET 或 SELECT

语法

SET 变量名=值 SELECT 变量名1=值1,变量名2=值2

从上面的语法大家可能已经看出两种赋值方式的区别了,SET只能给一个变量赋值,SELECT 可以给多个变量赋值。

例如

代码语言:javascript
复制
SET @A=3
SELECT @A=字段名1,@B=字段名2 FROM TABLE

变量常用场景

变量一般用作参数去给字段赋值,即将变量的值反过来赋值给字段。

我们以表Customers作为示例表

Customers

代码语言:javascript
复制
DECLARE @ID INT
DECLARE @NAME VARCHAR2(50)
DECLARE @ADDRESS VARCHAR2(50)
--用SET方法给变量赋值 , 此方法一次只能给一个变量赋值
SET @ID=1
--将部门ID为1的客户姓名和地址,赋值给@NAME和@ADDRESS变量 ,此方法能一次多个变量赋值
SELECT @NAME=姓名,@ADDRESS=地址 FROM Customers WHERE 客户ID=@ID
--查询变量里的结果
SELECT @NAME,@ADDRESS

结果如下:

如果我们想查询其他ID的姓名和地址,只需要更改一下@ID的值即可。

Q:可能有人会问,我直接把值写在客户ID后面不就可以了吗?为什么写这么长一段内容来要使用变量呢?

这里有两个原因

1、使用简便

当一个查询里同一个字段需要修改的地方较多的时候,我们只需要修改这个字段对应的变量内容,那么所有的字段对应的值都会一起跟着修改。

例如

要查询学生们对应的不同老师的信息:

代码语言:javascript
复制
DECLARE @ID INT
SET @ID=1
SELECT * FROM TEST 
WHERE Teacher=@ID AND Student='张三'
UNION ALL
SELECT * FROM TEST 
WHERE Teacher=@ID AND Student='李四'
UNION ALL
SELECT * FROM TEST 
WHERE Teacher=@ID AND Student='王五'
UNION ALL
SELECT * FROM TEST 
WHERE Teacher=@ID AND Student='马六'
UNION ALL
SELECT * FROM TEST 
WHERE Teacher=@ID AND Student='赵七'

我们只需要修改@ID的值,下面的所有查询的ID都会变更。

2、可以提高查询效率。

当我们使用查询的使用,数据库在执行这个查询语句的时候,如果不使用变量来修改值,实际上是两个查询。

例如:

代码语言:javascript
复制
SELECT * FROM TEST WHERE Student='张三';
SELECT * FROM TEST WHERE Student='李四'

执行这两个查询,数据库会制定两个执行计划,而制定执行计划是需要消耗系统资源的。

而如果我们改成:

代码语言:javascript
复制
DECLARE @NAME VARCHAR(20)
SET @NAME='张三'
SELECT * FROM TEST WHERE Student=@NAME

当我们修改@NAME的值为'李四'的时候,数据库还是会使用之前的执行计划。这样就节省了时间。

全局变量

全局变量使用@@来表示,一般都是系统预定义的一些全局变量。常用的全局变量有

  • @@ERROR ——最后一个SQL错误的错误号
  • @@IDENTITY —–最后一次插入的标识值
  • @@LANGUAGE —–当前使用的语言的名称
  • @@MAX_CONNECTIONS – 可以创建的同时连接的最大数目
  • @@ROWCOUNT —-受上一个SQL语句影响的行数
  • @@SERVERNAME —-本地服务器的名称
  • @@TRANSCOUNT —–当前连接打开的事物数
  • @@VERSION —–SQL Server的版本信息

例如查询数据库的版本号

代码语言:javascript
复制
PRINT @@VERSION

结果:

查询本地服务器的名称

代码语言:javascript
复制
PRINT @@SERVERNAME

结果:

这些信息都存储在全局变量中,当发生改变时,全局变量的值也会跟着改变。

本文参与?腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-05-08,如有侵权请联系?cloudcommunity@tencent.com 删除

本文分享自 SQL数据库开发 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com