如何测试mysql触发器和存储过程

 更新时间:2012年11月19日 16:09:37   作者:  
本文将详细介绍怎样mysql触发器和存储过程,需要了解的朋友可以详细参考下
1. 为了测试触发器和存储过程,首先建立一张简单的表:
复制代码 代码如下:

CREATE TABLE `airuser` (
`userId` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(128) NOT NULL,
PRIMARY KEY (`userId`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8

2. 为该表的插入操作,创建一张记录表:
复制代码 代码如下:

CREATE TABLE `airuser_record` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(45) DEFAULT NULL,
`edittime` timestamp NULL DEFAULT NULL,
`edittype` varchar(45) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

3. 编写一个插入操作的触发器:
复制代码 代码如下:

DROP TRIGGER insert_trigger;
delimiter |
CREATE TRIGGER insert_trigger BEFORE INSERT ON airuser
FOR EACH ROW BEGIN
INSERT INTO airuser_record SET username = NEW.username, edittime=now(), edittype='insert';
END;

SHOW TRIGGERS;

4. 为批量插入编写存储过程:
复制代码 代码如下:

DROP procedure createUsers;
delimiter |
create procedure createUsers(IN count int)
begin
declare i int;
set i=0;
while i<count do
insert into airuser set username=concat('user_',i);
set i=i+1;
end while;
end;

show procedure status;

5. 调用存储过程,验证存储过程是工作的,并验证在插入记录前,触发器能正确被触发:
复制代码 代码如下:

call createUsers(10);

6. 最后通过插入记录表再次验证:
复制代码 代码如下:

SELECT * FROM mars_jpa.airuser_record;

相关文章

  • MySQL中EXPLAIN命令详解

    MySQL中EXPLAIN命令详解

    在这里我们将介绍的是MySQL中EXPLAIN解释命令,希望对大家有所帮助
    2014-08-08
  • MySQL Shell import_table数据导入的实现

    MySQL Shell import_table数据导入的实现

    这篇文章主要介绍了MySQL Shell import_table数据导入的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • MySQL连接池DataSource的使用及实践

    MySQL连接池DataSource的使用及实践

    DruidDataSource作为一款优秀的数据库连接池组件,不仅提供了高效的连接管理,还包含了丰富的监控和诊断功能,本文主要介绍了MySQL连接池DataSource的使用及实践,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • SQL语句单引号与双引号的使用方法

    SQL语句单引号与双引号的使用方法

    这篇文章主要介绍了SQL语句中单引号、双引号的使用方法,分别讲述,虽然说的是Insert语句, 但是Select、Update、Delete语句都是一样的,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-03-03
  • MySql实现分布式锁详解

    MySql实现分布式锁详解

    这篇文章主要为大家详细介绍了如何使用本地MySql实现一把分布式锁,以及Mysql实现分布式锁的原理是怎么样的,有需要的小伙伴可以了解下
    2024-11-11
  • dbeaver如何导出mysql数据库

    dbeaver如何导出mysql数据库

    DBeaver导出MySQL数据库的简便方法:右键点击表选择“Tools”->“Dump database”,设定输出文件夹(例如桌面),点击开始即可导出SQL文件,此方法基于个人经验,供参考
    2024-10-10
  • SQL查询表字段信息详细图文教程

    SQL查询表字段信息详细图文教程

    最近工作用到SQL语句查询表中所有字段的名称,下面这篇文章主要给大家介绍了关于SQL查询表字段信息的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • 推荐没有虚拟主机的小巧的Mysql数据库备份脚本(PHP)

    推荐没有虚拟主机的小巧的Mysql数据库备份脚本(PHP)

    推荐没有虚拟主机的小巧的Mysql数据库备份脚本(PHP)...
    2007-07-07
  • MySQL数据库连接异常汇总(值得收藏)

    MySQL数据库连接异常汇总(值得收藏)

    这篇文章主要介绍了MySQL数据库连接异常汇总,帮助大家更好的理解和学习mysql,感兴趣的朋友可以了解下
    2020-08-08
  • windows下mysql 8.0.27 安装配置图文教程

    windows下mysql 8.0.27 安装配置图文教程

    这篇文章主要为大家详细介绍了windows下mysql 8.0.27 安装配置图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06

最新评论