前言
实战探讨主要来源于触发器的demo
1. 基本知识
@declare
语句用于声明变量
声明的变量可以用于存储临时数据,并在 sql 查询中多次引用
- 声明变量:使用 declare 语句声明一个或多个变量
- 变量命名:变量名以 @ 开头,后面跟随变量名
- 变量类型:必须为每个变量指定数据类型,如 int、varchar、date 等
- 赋值:使用 set 语句或在声明时直接赋值
- 使用变量:在查询中引用变量,可以进行各种操作,如条件判断、循环等
基本的语法如下:
declare @variable_name datatype;
2. demo
示例 1:简单声明和赋值
-- 声明一个整数变量,还可直接这样定义 declare @mynumber int=10; declare @mynumber int; -- 为变量赋值 set @mynumber = 10; -- 使用变量 select @mynumber as 'my number';
截图如下:
示例 2:在查询中使用变量
-- 声明变量 declare @firstname varchar(50); declare @lastname varchar(50); declare @fullname varchar(100); -- 赋值 set @firstname = 'john'; set @lastname = 'doe'; -- 连接字符串 set @fullname = @firstname + ' ' + @lastname; -- 使用变量 select @fullname as 'full name';
截图如下:
示例 3:在条件语句中使用变量
-- 声明变量 declare @threshold int; declare @result varchar(50); -- 赋值 set @threshold = 50; -- 条件判断 if @threshold > 100 set @result = 'above 100'; else set @result = '100 or below'; -- 使用变量 select @result as 'result';
截图如下:
示例 4:在循环中使用变量
-- 声明变量 declare @counter int; declare @maxcount int; -- 赋值 set @counter = 1; set @maxcount = 5; -- 循环 while @counter <= @maxcount begin print 'counter is ' + cast(@counter as varchar(10)); set @counter = @counter + 1; end
截图如下:
3. 拓展mysql
对于mysql的临时变量基本知识如下
- 声明变量:使用 set 或 select … into 语句来声明变量
- 变量命名:变量名以 @ 开头,后面跟随变量名
- 变量类型:mysql 中的变量不需要显式声明数据类型
- 使用变量:在查询中引用变量,可以进行各种操作,如条件判断、循环等
基本语法如下:
set @variable_name = value;
与上面同理,demo如下:
示例 1:简单声明和赋值
-- 声明并赋值变量 set @mynumber = 10; -- 使用变量 select @mynumber as 'my number';
截图如下:
示例 2:在查询中使用变量
-- 声明并赋值变量 set @firstname = 'john'; set @lastname = 'doe'; -- 连接字符串 set @fullname = concat(@firstname, ' ', @lastname); -- 使用变量 select @fullname as 'full name';
截图如下:
示例 3:在条件语句中使用变量
– 声明并赋值变量 set @threshold = 50; – 条件判断 if @threshold > 100 then set @result = ‘above 100'; else set @result = ‘100 or below'; end if; – 使用变量 select @result as ‘result';
截图如下:
示例 4:在循环中使用变量 (必须将循环逻辑封装在存储过程(或存储函数)中)
delimiter $$ create procedure loopexample() begin declare counter int default 1; declare maxcount int default 5; -- 使用准备好的语句进行循环 prepare stmt from 'select ? as counter'; while counter <= maxcount do execute stmt using @counter; set counter = counter + 1; end while; deallocate prepare stmt; end$$ delimiter ; -- 调用存储过程 call loopexample();
截图如下:
4. 彩蛋
以下为错误的demo
对于循环遍历,mysql中不适合使用if,需要使用case
-- 声明并赋值变量 set @threshold = 50; -- 条件判断 if @threshold > 100 then set @result = 'above 100'; else set @result = '100 or below'; end if; -- 使用变量 select @result as 'result';
以及不可直接使用如下方式
-- 声明并赋值变量 set @counter = 1; set @maxcount = 5; -- 使用准备好的语句进行循环 prepare stmt from 'select ? as counter'; while @counter <= @maxcount do execute stmt using @counter; set @counter = @counter + 1; end while; deallocate prepare stmt;
到此这篇关于sql server中的declare基本知识的文章就介绍到这了,更多相关sql server declare内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论