比别人多一点志气,你就会多一份出息 [登录·注册]

吕滔博客

首页 开发 运维 工具 摄影

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

工具 memory 发布于January 10, 2017 标签: MySQL

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中的数据如你所愿的发生了变化。

相关推荐

添加新评论

网站状态

  • 栏目分类:49个
  • 发布文章:1534篇
  • 用户评论:754条
  • 开博至今:4129天

正则速查

[abc] 匹配中括号中的单个字符,如a或b或c
[^abc] 匹配除了a、b、c等字符的其他单个字符
[a-z] 匹配一个字符范围,如a到z
[a-zA-Z] 匹配一个字符范围,如a-z 或 A-Z
^ 匹配行的开始
$ 匹配行的结束
\A 匹配一个字符串的开始
\z 匹配一个字符串的结束
. 匹配任意单个字符
\s 匹配空白字符,如空格,TAB
\S 匹配非空白字符
\d 匹配一个数字
\D 匹配非数字
\w 匹配一个字母
\W 匹配非字母
\b 匹配字符边界
(...) 引用所有括号中的内容
(a|b) a或者b
a? 零个或1个a
a* 零个或多个a
a+ 1个或多个a
a{3} 3次重复的a
a{3,} 3次或3次以上重复的a
a{3,6} 3到6次重复的a

修正符

/g 查找所有可能的匹配
/i 不区分大小写
/m 多行匹配
/s 单行匹配
/x 忽略空白模式
/e 可执行模式,PHP专有
/A 强制从目标字符串开头匹配
/D 使用$限制结尾字符,则不允许结尾有换行
/U 只匹配最近的一个字符串;不重复匹配

最新回复

  • memory: 你可以在vps里写个shell脚本,将网站部分目录的部分文件监控...
  • 志方: 这些都设置成功了,我是想问下,我在服务器的web站点更新了配置信...
  • 羊毛: 感谢分享
  • hyvm.net: 好文章,点赞
  • 新闻头条: 文章不错非常喜欢
  • 志志: 折腾了半天 感谢大神
  • Smithk464: Hey very nice blog!! Man .. Exce...
  • memory: 我已投奔phpstrom.哈哈
  • 逆风飘扬: 原来是这样!!!!!!!用惯了VS的来用zend studio没...
  • NS: 请问我这么写之后抛出了一个 javax.crypto.BadPa...
  • memory: 有内部使用的,开源的过段时间放个出来。
  • 小小: 博主 ,可有写好的
  • 111: 我看不懂唉,好多内容
  • memory: 咧,难道我手误了,回头看下官方文档去...
  • 阿东: 进入镜像的 后面 /bin/bash 是错的 你应该用的是/b...
  • memory: 帝国的安全性来说,比phpcms和dede要好的多啦.
  • 西点师培训班: 现在帝国用的少了,开源的不太会改,老被黑