前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql变量声明、存储过程、触发器

mysql变量声明、存储过程、触发器

作者头像
友儿
发布2022-09-28 13:25:18
1.7K0
发布2022-09-28 13:25:18
举报
文章被收录于专栏:友儿

变量声明

服务器系统变量

  • 通过@@来调用系统变量
代码语言:javascript
复制
# 列出mysql所有系统变量
SHOW VARIABLES
SELECT @@date_format

用户变量

  • 通过@来调用用户变量
代码语言:javascript
复制
# 输出变量yesterday
SELECT @yesterday

# 对变量yesterday进行赋值
SET @yesterday=subdate(CURRENT_DATE, 1);

# 日期的格式化
SET @yesterday=DATE_FORMAT(@yesterday, "%Y/%m/%d");

# 小数的格式化
SET @amount=0.4;
SET @amount=CAST(@amount as DECIMAL(15, 3));
SELECT @amount

局部变量

  • 不需要@前缀
  • 需要事先进行变量类型的声明和初始化

存储过程

简单地认为是SQL中的函数

声明一个存储过程

  • 创建存储过程
    • 每一句语句结束之后都要添加分号;
代码语言:javascript
复制
CREATE PROCEDURE stat_store_perf(days INT)
BEGIN
    DECLARE t_date VARCHAR(255);
    set t_date = DATE_FORMAT(subdate(CURRENT_DATE, days), '%Y-%m-%d');
    SELECT count(*) as 店铺数, 
    FORMAT(AVG(amount), 2) as 平均业绩,
    SUM(amount) as 总业绩,
    MAX(amount) as 最大业绩,
    MIN(amount) as 最小业绩,
    department as 部门 
    FROM store_perf WHERE sta_date=t_date
    GROUP BY department;
END    

调用存储过程

代码语言:javascript
复制
CALL stat_store_perf(1)

删除存储过程

代码语言:javascript
复制
DROP PROCEDURE stat_store_perf

触发器

和存储过程一样, 都是嵌入到mysql中的一段程序, 区别就是存储过程需要显式调用, 而触发器式根据对表的相关操作自动激活执行.

  • 创建触发器
代码语言:javascript
复制
CREATE TRIGGER 触发器名
BEFORE[AFTER] [INSERT, UPDATE, DELETE]


CREATE TRIGGER check_department
BEFORE INSERT
ON store_perf
FOR each row
BEGIN
    IF new.department not in ("男装事业部", "女装事业部") THEN
    SET new.department 'unknow';
    END IF;
END
  • 触发器的应用

多用来检查字段

  • 查看触发器

建议通过客户端删除

代码语言:javascript
复制
SHOW TRIGGERS FROM store_perf
  • 删除触发器

建议通过客户端删除

代码语言:javascript
复制
DROP TRIGGERS check_department
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 变量声明
  • 存储过程
  • 触发器
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档