mysql数据库触发器怎么用_如何运用MySQL数据库创建触发器

软件安装:装机软件必备包

SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。MySQL中的触发器是由insert、update和delete等事件来触发某种特定操作,满足触发器的触发条件,数据库就会执行触发器中定义的程序语句,并且触发器的执行语句可能只有一个,也可能有多个。那怎么实现创建触发器,具体操作如下:

ace078a812472c0eefb3438d8cd69d11.png

1.首先,在数据库world下找到“触发器”,鼠标右键“创建触/发器”,弹出输入新触发器名称,填写名称“city_trigger”,

如下图所示:

dd90912063ecbac20ba0dbd553446ddf.png

2.输入完毕,单击“创建”按钮,生成city_trigger,

如下图所示:

d45ee9c0173b30c71bbfa25313647d1c.png

3.为了不影响其他表结构,这里新建一张数据库表t_city_info,代码如下:

CREATE TABLE `world`.`t_city_info`(

`id` INT(8) NOT NULL AUTO_INCREMENT COMMENT 'ID',

`city_code` INT(4) COMMENT '城市编码',

`city_name` VARCHAR(20) COMMENT '城市名称',

`city_detail` VARCHAR(100) COMMENT '描述',

PRIMARY KEY (`id`)

) CHARSET=utf8;

如下图所示:

0981b929438378681042aac890b02ef3.png

19cb91deeb15ea730f90cd636ebb7982.png

4.数据库表t_city_info创建完毕后,修改触发器代码,代码如下:

DELIMITER $$

USE `world`$$

DROP TRIGGER /*!50032 IF EXISTS */ `city_trigger`$$

CREATE

/*!50017 DEFINER = 'root'@'localhost' */

TRIGGER `city_trigger` BEFORE INSERT ON `t_city_info`

FOR EACH ROW BEGIN

INSERT INTO t_tri_time VALUES (NOW());

END;

$$

DELIMITER ;

如下图所示:

34fcadc15afb3f1e3ab472a7a7846f58.png

5.修改 `city_trigger`触发器,点击运行按钮,并刷新数据库,可以在触发器文件夹下查看到 `city_trigger`,

如下图所示:

049f7f736a297131b16f914580557656.png

6.然后,先t_city_info中插入一条数据,代码如下:

然后,先t_city_info中插入一条数据,代码如下:

INSERT INTO t_city_info (

id,

city_code,

city_name,

city_detail

)

VALUES

(1000, 100, '武汉', '武汉市') ;

点击运行后,出现错误,错误代码如下:

1 queries executed, 0 success, 1 errors, 0 warnings

查询:insert into t_city_info ( id, city_code, city_name, city_detail ) values (1000, 100, '武汉', '武汉市')

错误代码: 1146

Table 'world.t_tri_time' doesn't exist

执行耗时 : 0 sec

传送时间 : 0 sec

总耗时 : 0.012 sec

如下图所示:

565032928536f1428f72c930ee911e2f.png

7.由于t_tri_time不存在,导致出错,接着创建t_tri_time数据库表,

如下图所示:

03f19a75d21e6bb87b0de4f978ea88f6.png

8.再次执行插入语句,结果成功;然后,查询t_tri_time数据库表,代码如下:

SELECT * FROM t_tri_time;

如下图所示:

9752343f9980a66f0d4c27de2e0e8b43.png

98bcac7b1cc148b52ef3491476877c2e.png

说明:

注意数据库触发器创建语法

了解数据库表增删改查语法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据库系统概论课程设计之“图书馆数据库管理系统” ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 小组成员: *** QQ:763157698 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ “图书馆数据库备份文件”使用说明: 1、数据库备份文件还原时,应先将同目录下的备份文件 "LibrarySystem" 放置于“D:\LibrarySystem\”目录下; 2、该数据库使用到的所有数据均备份在同目录下的文件 "LibrarySystem" 中,读者可以根据需要还原数据、测试数据; 3、本课程设计附有“图书馆数据库管理系统的所有源代码”,您可以根据需要在“第四章节”至“第七章节”中进行查看,或查看与本课程设计处于同一目录下的 *.sql 源代码文件! 本图书馆管理系统谨根据实际需求所创建创建有如下八个数据表:Book(图书信息表),Dept(学生系部信息表),Major(学生专业信息表),Student(学生信息表),StudentBook(学生借阅图书信息表),Teacher(教师信息表),TeacherBook(教师借阅图书信息表),RDeleted(读者还书信息表)等。这些数据表结合图书馆数据库中的五个存储过程,即实现了普通图书馆的大部分功能。如读者借阅图书功能(Execute RBorrowBook '读者号','图书分类号'),读者归还图书功能(Execute RReturnBook '读者号','图书分类号'),读者续借图书功能(Execute RRenewBook '读者号','图书分类号'),读者查询图书借阅情况功能(Execute RQueryBook '读者号'),读者检索的图书信息功能(Execute RIndexBook '关键字')等。具体的功能表现皆在“第三章、图书馆管理系统功能图例”中有详细的图例说明。 本图书馆管理系统谨根据实际需要,创建了七个触发器,就此,创作者对这些触发器做如下说明: 1、tri_Book 功能表现:只有在图书馆内相关书籍尚有库存的情况下,读者才可以进行借阅操作 2、tri_SborrowNum 功能表现:控制学生的图书借阅量在5本以内(包括5本) 3、tri_SrenewBook 功能表现:控制学生续借图书次数在3次以内(包括3次) 4、tri_SreturnBook 功能表现:将学生的还书信息插入RDeleted表 5、tri_TborrowNum 功能表现:控制教师的图书借阅量在10本以内(包括10本) 6、tri_TrenewBook 功能表现:控制学生续借图书次数在4次以内(包括4次) 7、tri_TreturnBook 功能表现:将教师的还书信息插入RDeleted表 本图书馆管理系统设计思路较为肤浅,但在一定程度上实现了图书馆数据库管理系统的实用功能。初次设计数据库,其中肯定会有不足之处,还望读者谅解!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值