废话不多说,直接进入正题...

一、存储过程

a、概述

  • 存储过程可以看成是对一系列 SQL 操作的批处理;
  • 使用存储过程的好处
    1. 代码封装,保证了一定的安全性;
    2. 代码复用;
    3. 由于是预先编译,因此具有很高的性能。
  • 创建存储过程
    1. 命令行中创建存储过程需要自定义分隔符,因为命令行是以 ; 为结束符,而存储过程中也包含了分号,因此会错误把这部分分号当成是结束符,造成语法错误。
    2. 包含 in、out 和 inout 三种参数。
    3. 给变量赋值都需要用 select into 语句。
    4. 每次只能给一个变量赋值,不支持集合的操作。

b、创建存储过程

  • DROP PROCEDURE IF EXISTS `proc_adder`;
  • DELIMITER ;;
  • CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_adder`(IN a int, IN b int, OUT sum int)
  • BEGIN
  • DECLARE c int;
  • if a is null then set a = 0;
  • end if;
  • if b is null then set b = 0;
  • end if;
  • set sum = a + b;
  • END
  • ;;
  • DELIMITER ;

c、使用存储过程

  • set @b=5;
  • call proc_adder(2,@b,@s);
  • select @s as sum;

二、游标

a、概述

  • 游标(cursor)是一个存储在 DBMS 服务器上的数据库查询,它不是一条 SELECT 语句,而是被该语句检索出来的结果集。
  • 在存储过程中使用游标可以对一个结果集进行移动遍历。
  • 游标主要用于交互式应用,其中用户需要对数据集中的任意行进行浏览和修改。
  • 使用游标的四个步骤:
    1. 声明游标,这个过程没有实际检索出数据;
    2. 打开游标;
    3. 取出数据;
    4. 关闭游标;

SQL语句示例:

  • DELIMITER $
  • CREATE PROCEDURE getTotal()
  • BEGIN
  • DECLARE total INT;
  • -- 创建接收游标数据的变量
  • DECLARE sid INT;
  • DECLARE sname VARCHAR(10);
  • -- 创建总数变量
  • DECLARE sage INT;
  • -- 创建结束标志变量
  • DECLARE done INT DEFAULT false;
  • -- 创建游标
  • DECLARE cur CURSOR FOR SELECT id,name,age from cursor_table where age>30;
  • -- 指定游标循环结束时的返回值
  • DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = true;
  • SET total = 0;
  • OPEN cur;
  • FETCH cur INTO sid, sname, sage;
  • WHILE(NOT done)
  • DO
  • SET total = total + 1;
  • FETCH cur INTO sid, sname, sage;
  • END WHILE;
  • CLOSE cur;
  • SELECT total;END $DELIMITER ;
  • -- 调用存储过程
  • call getTotal();

三、触发器

a、概述

  • 触发器是一种与表操作有关的数据库对象,当触发器所在表上出现指定事件时,将调用该对象,即表的操作事件触发表上的触发器的执行

可以使用触发器来进行审计跟踪,把修改记录到另外一张表中。

MySQL 不允许在触发器中使用 CALL 语句 ,也就是不能调用存储过程。

  • BEGIN 和 END

    • 当触发器的触发条件满足时,将会执行 BEGIN 和 END 之间的触发器执行动作。
    • 注意:
      • 在 MySQL 中,分号 ; 是语句结束的标识符,遇到分号表示该段语句已经结束,MySQL 可以开始执行了。因此,解释器遇到触发器执行动作中的分号后就开始执行,然后会报错,因为没有找到和 BEGIN 匹配的 END。
      • 这时就会用到 DELIMITER 命令(DELIMITER 是定界符,分隔符的意思)。它是一条命令,不需要语句结束标识,语法为:DELIMITER new_delemiter。new_delemiter 可以设为 1 个或多个长度的符号,默认的是分号 ;,我们可以把它修改为其他符号,如 $ - DELIMITER $ 。在这之后的语句,以分号结束,解释器不会有什么反应,只有遇到了 $,才认为是语句结束。注意,使用完之后,我们还应该记得把它给修改回来。
  • NEW 和 OLD
    • MySQL 中定义了 NEW 和 OLD 关键字,用来表示触发器的所在表中,触发了触发器的那一行数据。
    • 在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
    • 在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据;
    • 在 DELETE 型触发器中,OLD用来表示将要或已经被删除的原数据;
    • 使用方法: NEW.columnName(columnName 为相应数据表某一列名)

b、创建触发器

提示:为了理解触发器的要点,有必要先了解一下创建触发器的指令。

    • CREATE TRIGGER 指令用于创建触发器。
    • 语法:
      • CREATE TRIGGER trigger_name
      • trigger_time
      • trigger_event
      • ON table_name
      • FOR EACH ROW
      • BEGIN
      • trigger_statements
      • END;
    • 说明:
      • trigger_name:触发器名
      • trigger_time: 触发器的触发时机。取值为 BEFORE 或 AFTER。
      • trigger_event: 触发器的监听事件。取值为 INSERT、UPDATE 或 DELETE。
      • table_name: 触发器的监听目标。指定在哪张表上建立触发器。
      • FOR EACH ROW: 行级监视,Mysql 固定写法,其他 DBMS 不同。
      • trigger_statements: 触发器执行动作。是一条或多条 SQL 语句的列表,列表内的每条语句都必须用分号 ; 来结尾。
    • 示例:
      • DELIM ITER $
      • CREATE TRIGGER `trigger_insert_user`
      • AFTER INSERT ON `user`
      • FOR EACH ROW
      • BEGIN
      • INSERT INTO `user_history`(user_id, operate_type, operate_time)
      • VALUES (NEW.id, 'add a user', now());
      • END $
      • DELIMITER ;

c、查看触发器

SHOW TRIGGERS;

d、删除触发器

DROP TRIGGER IF EXISTS trigger_insert_user;

    mysql高级进阶(存储过程、游标、触发器)的更多相关文章

    1. mysql 自己定义存储过程和触发器

      mysql 自己定义存储过程和触发器 --存储过程示范 DROP PROCEDURE IF EXISTS PRO_TEST; CREATE PROCEDURE PRO_TEST(IN NUM_IN I ...

    2. MySQL笔记 存储过程 游标 触发器

      第二十三章 使用存储过程 MySQL5 中添加了存储过程的支持. 大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成 存储过程简单来说,就 ...

    3. MySQL必知必会笔记(六)存储过程 游标 触发器

      留印:http://blog.sina.com.cn/s/articlelist_1254871964_5_1.html   第二十三章 使用存储过程     MySQL5 中添加了存储过程的支持. ...

    4. Mysql高级之存储过程

      参考地址1:http://www.2cto.com/database/201411/350819.html 参考地址2:http://www.jb51.net/article/39471.htm my ...

    5. mysql 数据库 简单存储过程游标使用

      BEGIN #Routine body goes here... DECLARE no_more_record INT DEFAULT 0; DECLARE TEST_ID INT(20); DECL ...

    6. MYSQL如何导出存储过程和触发器?

      今天遇到.. 类似下面的就可以: mysqldump -u root -p -ntd -R  nxsc>nxsc_trigger.sql

    7. MySQL高级语句(一)

      一.MySQL高级进阶SQL 语句 1.SELECT 2.DISTINCT 3.WHERE  4.AND.OR 5.IN 6.BETWEEN 7.通配符.LIKE 8.ORDER BY 9.| | 连 ...

    8. Mysql 视图 游标 触发器 存储过程 事务

      Mysql 视图 触发器 存储过程 游标 游标是从数据表中提取出来的数据,以临时表的形式存放在内存中,在游标中有一个数据指针,在初始状态下指向的是首记录,利用fetch语句可以移动该指针,从而对游标中 ...

    9. 利用navicat创建存储过程、触发器和使用游标的简单实例

      利用navicat创建存储过程.触发器和使用游标的简单实例 标签: navicat存储过程触发器mysql游标 2013-08-03 21:34 15516人阅读 评论(1) 收藏 举报  分类: 数 ...

    10. MySQL存储过程 游标

      MySQL存储过程  游标 如何在存储过程中使用MySQL游标来遍历SELECT语句返回的结果集 MySQL游标简介 要处理存储过程中的结果集,请使用游标.游标允许您迭代查询返回的一组行,并相应地处理 ...

    随机推荐

    1. LeeCode 713 乘积小于k的子数组

      LeeCode 713 题目描述: 给你一个整数数组 nums 和一个整数 k ,请你返回子数组内所有元素的乘积严格小于 k 的连续子数组的数目. 标签: 双指针.滑动窗口 建立模型 枚举子数组的右端 ...

    2. MySQL(十三)MySQL性能分析工具:慢查询日志与PROFILE查询成本

      性能分析工具SLOW QUERY LOG.PROFILE的使用 ​ 数据库调优的目标就是响应速度更快,吞吐量更大.利用宏观的监控工具和微观的日志分析可以帮助我们找到调优的思路和方式. 数据库调优的步骤 ...

    3. Karmada 多云容器编排引擎支持多调度组,助力成本优化

      摘要:Karmada 社区也在持续关注云成本的管理,在最近发布的 v1.5 版本中,支持用户在分发策略 PropagationPolicy/ClusterPropagationPolicy 中设置多个 ...

    4. 【FAQ】统一扫码服务常见问题及解答

      1.隐私政策是怎么样的?收集哪些信息? 关于Scan Kit的隐私政策及收集的信息,请查看SDK隐私安全说明. Android:SDK隐私安全说明 iOS:SDK隐私安全说明 2.如何使用多码识别?多 ...

    5. 机器学习07-(中文分词、样本类别均衡化、置信概率、k-means聚类算法、均值漂移聚类算法)

      机器学习-07 机器学习-07 中文分词(jieba) 样本类别均衡化 置信概率 聚类模型 K均值算法 均值漂移算法 轮廓系数 DBSCAN算法 推荐引擎 代码总结 结巴分词 酒店评论舆情分析 针对测 ...

    6. Swift WisdomProtocol 面向协议编程(下)

      WisdomProtocol 面向协议编程(下) @[TOC] WisdomProtocol SDK 面向协议编程 # Welcome to use WisdomProtocol WisdomProt ...

    7. 推荐一个.Net Core开发的Websocket群聊、私聊的开源项目

      今天给大家推荐一个使用Websocket协议实现的.高性能即时聊天组件,可用于群聊.好友聊天.游戏直播等场景. 项目简介 这是一个基于.Net Core开发的.简单.高性能的通讯组件,支持点对点发送. ...

    8. 2020-10-24:go中channel的recv流程是什么?

      福哥答案2020-10-24: ***[评论](https://user.qzone.qq.com/3182319461/blog/1603496305)

    9. 2021-09-20:给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O

      2021-09-20:给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度.不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O ...

    10. vue全家桶进阶之路31:Vue3 数据和方法的双向绑定ref、reactive、toRefs

      ref 在 Vue 3 中,你可以使用 setup 函数来定义组件的数据和方法.在 setup 函数中,你可以使用 ref.reactive 和 computed 等 Vue 3 的响应式 API 来 ...