SQL查询-设置局部变量(PostgreSQL、MySQL)

😋博主在工作中编写复杂SQL语句时,经常需要替换查询值进行测试。所以需要用到局部变量设置,可以减轻测试时的压力。

目录

使用场景

🤔在user_info表、user_info_ex表、user_info_in表,三个表中查询工号为'STAF0306'的记录并返回,SQL示例如下。

1.常规写法

javascript 复制代码
select 
	user_id, user_name, user_code
from user_info
where
	user_code = 'STAF0306'
	
union 

select 
	user_id, user_name, user_code
from user_info_ex
where
	user_code = 'STAF0306'

union 

select 
	user_id, user_name, user_code
from user_info_in
where
	user_code = 'STAF0306'

2.局部变量写法

如果需要改为查询'STAF0308'的工号时,需要替换三个位置。在简单的语句中替换没有什么影响,但如果在复杂的SQL中,可能会出现漏改的情况😥。

所以,我们可以在顶部显眼位置设置局部参数,直接修改所需的入参,可无视复杂的SQL语句👏。

(1)PostgreSQL示例

🙆‍♂️使用current_setting('parameter_name') 来获取参数值,并注意设置对应的参数类型

javascript 复制代码
SET my.user_code TO 'STAF0308';

select 
	user_id, user_name, user_code
from user_info
where
	user_code = current_setting('my.user_code')::VARCHAR
	
union 

select 
	user_id, user_name, user_code
from user_info_external
where
	user_code = current_setting('my.user_code')::VARCHAR
注意事项
复制代码
1)SET LOCAL 需要在事务块中使用(BEGIN...COMMIT)
2)使用 SET 可以在事务外使用
3)参数值总是字符串,需要根据需要进行类型转换

(2)MySQL示例

🙆‍♀️用户变量以 @ 开头,在会话内有效,注意大小写。

javascript 复制代码
SET @user_code = 'STAF0308';

select 
	user_id, user_name, user_code
from user_info
where
	user_code = @user_code
	
union 

select 
	user_id, user_name, user_code
from user_info_external
where
	user_code = @user_code

union 

select 
	user_id, user_name, user_code
from user_info_in
where
	user_code = @user_code
注意事项
复制代码
1)用户变量以 @ 开头,在会话内有效
2)局部变量在存储过程内使用 DECLARE 定义,不以 @ 开头
3)变量名区分大小写
4)用户变量会在会话结束后自动清除

结语

🎈以上博主仅列出了两种较为简单的设置局部变量方式,还有许多其他的设置方式就不做扩展说明了,感谢阅读。

相关推荐
摇滚侠6 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
ApacheSeaTunnel8 小时前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
DARLING Zero two♡8 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
BD_Marathon9 小时前
SQL学习指南——视图
数据库·sql
活宝小娜9 小时前
mysql详细安装教程
数据库·mysql·adb
秉承初心10 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle
Database_Cool_10 小时前
什么是数据仓库物化视图?AnalyticDB MySQL 实时物化视图能力解析
人工智能·mysql·阿里云
2601_9620725510 小时前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
Database_Cool_10 小时前
即席查询(Ad-Hoc)数据库选型:AnalyticDB MySQL 秒级 Ad-Hoc 分析方案
数据库·mysql
一杯奶茶¥10 小时前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目