navicat中创建存储过程、触发器和使用游标的简单实例(图文)

 更新时间:2017年02月05日 20:12:59   投稿:mdxy-dxy  
这篇文章主要介绍了navicat中创建存储过程、触发器和使用游标的简单实例,需要的朋友可以参考下

1、建表
首先先建两张表(users表和number表),具体设计如下图:
1.jpg
2.jpg

2、存储过程
写一个存储过程,往users表中插入数据,创建过程如下:
3.jpg
4.jpg
5.jpg

代码如下

BEGIN
 #Routine body goes here...
 declare n bigint;
 set n = 201121029684;
 while n <= 201121029694
 do
 insert into users(student_ID) values(n);
 set n = n + 1;
 end while;
END

6.jpg
执行存储过程后可以看到users表中的数据如下:
7.jpg

整个存储过程的编写就完成了,当然这只是一个极为简单的例子,仅供入门参考。

3、触发器

在写触发器之前,我们先把users的数据清空

truncate table users; 

现在我们有两个表,我要做的事情就是,当我往users中插入数据后,number中也相应变化:

例如,number表中有一条初始数据,id=1,num=0;

当我往users中插入一条数据后,就触发number表中的num字段就加1,也就是记录用户数。

下面我们来实现这个小小的功能。

右击users表,选择设计表

8.jpg
选择触发器选项
9.jpg
10.jpg
11.jpg

begin
 update number
 set num = (select count(*) from users) ;
end

保存后,再往users表中添加新数据,再查看一下number中的数据,你会神奇的发现,number表中的数据也变了,自己动手试一下吧!

ps:存储过程需要程序员自己去执行,触发器,顾名思义,自动触发。

4、游标使用
我现在想做的是将student_ID字段都加上100,通过这个例子简单展示一下游标的使用。

创建一个存储过程,创建方式参考上面步骤。存储过程代码如下:

12.jpg

BEGIN
 #Routine body goes here...

 declare tmp bigint default 0;
 declare cur CURSOR FOR SELECT student_ID FROM users; -- 定义游标
 /*
 02000 发生下述异常之一: 
 SELECT INTO 语句或 INSERT 语句的子查询的结果为空表。 
 在搜索的 UPDATE 或 DELETE 语句内标识的行数为零。 
 在 FETCH 语句中引用的游标位置处于结果表最后一行之后。


 */
 declare CONTINUE HANDLER FOR SQLSTATE '02000' set tmp = 0; 


 OPEN cur; -- 打开游标
 FETCH cur INTO tmp; -- 游标向下走一步


 WHILE(tmp != 0)
 DO 
 select tmp; -- 将tmp打印出来,会发现tmp就像一个指针,一开始指向第一行,游标走一步,则指向下一行记录


 UPDATE users
 SET student_ID = tmp + 100
 WHERE student_ID = tmp;
 FETCH cur INTO tmp;
 END WHILE;

 CLOSE cur; -- 关闭游标
END

执行上面的存储过程,你会发现,users中的数据如你所愿的发生了变化。

相关文章

  • MySQL数据库查看日志操作指南

    MySQL数据库查看日志操作指南

    这篇文章主要介绍了MySQL数据库查看日志操作的相关资料,文中讲了MySQL中的四种日志,分别是错误日志、二进制日志、查询日志和慢查询日志,需要的朋友可以参考下
    2025-02-02
  • MySQL的DELETE(删除数据)用法解读

    MySQL的DELETE(删除数据)用法解读

    本文将详细介绍DELETE语句的基本语法、高级用法、性能优化策略以及注意事项,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • 5个MySQL GUI工具推荐,帮助你进行数据库管理

    5个MySQL GUI工具推荐,帮助你进行数据库管理

    这篇文章主要介绍了5个MySQL GUI工具推荐,帮助大家更好的进行MySQL数据库管理,感兴趣的朋友可以了解下
    2020-08-08
  • Mac上安装MySQL过程分享

    Mac上安装MySQL过程分享

    这篇文章主要介绍了Mac上安装MySQL过程分享,本文共分4步完成,简单易懂,需要的朋友可以参考下
    2014-11-11
  • mysql数据库分区的使用

    mysql数据库分区的使用

    MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下
    2025-01-01
  • MySQL PHP语法浅析

    MySQL PHP语法浅析

    在本篇文章里小编给大家分享了关于MySQL PHP语法的相关知识点,需要的朋友们学习参考下。
    2019-02-02
  • mysql表的内连和外连实战记录

    mysql表的内连和外连实战记录

    在开发中我们的业务需求有时候是复杂的,多张表联合查询的时候是有多种方式的,面对不同的需求,灵活使用不同的表连接方式,这篇文章主要给大家介绍了关于mysql表内连和外连的相关资料,需要的朋友可以参考下
    2024-01-01
  • Mysql5.7修改root密码教程

    Mysql5.7修改root密码教程

    本文给大家分享的是个人在使用mysql5.7修改root密码的时候遇到的问题,以及解决方法,推荐给有相同需求的小伙伴参考下。
    2016-02-02
  • MySQL中预处理语句prepare、execute与deallocate的使用教程

    MySQL中预处理语句prepare、execute与deallocate的使用教程

    这篇文章主要介绍了MySQL中预处理语句prepare、execute与deallocate的使用教程,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面跟着小编一起来学习学习吧。
    2017-08-08
  • MySQL获取当前时间的多种方式总结

    MySQL获取当前时间的多种方式总结

    负责的项目中使用的是mysql数据库,页面上要显示当天所注册人数的数量,获取当前的年月日,下面这篇文章主要给大家总结介绍了关于MySQL获取当前时间的多种方式,需要的朋友可以参考下
    2023-02-02

最新评论