MySQL触发器自动智能化的数据维护

目录
  • 触发器介绍
    • 触发器的特性
    • 触发器语法
  • 数据准备
    • 创建触发器
    • 触发器——执行多个触发语句
  • New Old 操作
    • 查看触发器
    • 删除触发器
  • 总结

触发器介绍

触发器,就是一种特殊的存储过程。触发器和存储过程一样是一个能够完成特定功能、存储在数据库服务器上的SQL片段,但是触发器无需调用,当对数据库表中的数据执行DML操作时自动触发这个SQL片段的执行,无需手动条用。

在MySQL中,只有执行insert,delete,update操作时才能触发触发器的执行

触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验等操作 

使用别名 OLD 和 NEW 来引用触发器中发生变化的记录内容,这与其他的数据库是相似的。现在触发器还只支持行级触发,不支持语句级触发

触发器的特性

  • 1、什么条件会触发:I、D、U
  • 2、什么时候触发:在增删改前或者后
  • 3、触发频率:针对每一行执行
  • 4、触发器定义在表上,附着在表上

触发器语法

1、创建只有一个执行语句的触发器

create trigger 触发器名 before|after 触发事件
on 表名 for each row
执行语句;

2、创建有多个执行语句的触发器

create trigger 触发器名 before|after 触发事件
on 表名 for each row
begin
执行语句列表
end;

数据准备

-- 数据准备
create database if not exists db_trigger;
use mydb10_trigger;
-- 用户表
create table user(
uid int primary key ,
username varchar(50) not null,
password varchar(50) not null
);
-- 用户信息操作日志表
create table user_logs(
id int primary key auto_increment,
time timestamp,
log_text varchar(255)
);

创建触发器

-- 如果触发器存在,则先删除
drop trigger if exists trigger_test1;
-- 创建触发器trigger_test1
create trigger trigger_test1
after insert on user -- 触发时机:当添加user表数据时触发
for each row
insert into user_logs values(NULL,now(), '有新用户注册');
-- 添加数据,触发器自动执行并添加日志代码
insert into user values(1,'张三','123456');

从上面的语法我们可以知道,触发器的基本的结构是怎样的

create trigger 触发器名称 after(before)insert(update,delete)on 表名(监控表) for each row 执行语句

触发器——执行多个触发语句

-- 如果触发器trigger_test2存在,则先删除
drop trigger if exists trigger_test2;
-- 创建触发器trigger_test2
delimiter $$
create trigger trigger_test2
after update on user -- 触发时机:当修改user表数据时触发
for each row -- 每一行
begin
insert into user_logs values(NULL,now(), '用户修改发生了修改');
end $$
delimiter ;
-- 添加数据,触发器自动执行并添加日志代码
update user set password = '888888' where uid = 1;

这里,采用了标准的格式进行触发器的语法格式,可以定义多个执行语句,将所有的执行语句写在begin end $$里面,也就是需要采用这样的方式包裹住。

delimiter $$ create trigger 触发器名称 after(before)insert(update,delete)on 表名 for each row  begin 执行语句 end $$ delimiter;

也就是说我们将出发语句,放在了begin 和 end $$ 中间

New Old 操作

MySQL 中定义了 NEW 和 OLD,用来表示触发器的所在表中,触发了触发器的那一行数据,来引用触发器中发生变化的记录内容,具体地:


触发器类型


触发器类型NEW 和 OLD的使用


INSERT 型触发器


NEW 表示将要或者已经新增的数据


UPDATE 型触发器


OLD 表示修改之前的数据 , NEW 表示将要或已经修改后的数据


DELETE 型触发器


OLD 表示将要或者已经删除的数据

使用方法:

NEW.columnName (columnName为相应数据表某一列名)

create trigger trigger_test3 after insert
on user for each row
insert into user_logs values(NULL,now(),concat('有新用户添加,信息为:',NEW.uid,NEW.username,NEW.password));
-- 测试
insert into user values(4,'赵六','123456');

查看触发器

show triggers;

删除触发器

-- drop trigger [if exists] trigger_name
drop trigger if exists trigger_test1;
  • 1.MYSQL中触发器中不能对本表进行 insert ,update ,delete 操作,以免递归循环触发
  • 2.尽量少使用触发器,假设触发器触发每次执行1s,insert table 500条数据,那么就需要触发500次触发器,光是触发器执行的时间就花费了500s,而insert 500条数据一共是1s,那么这个insert的效率就非常低了。
  • 3. 触发器是针对每一行的;对增删改非常频繁的表上切记不要使用触发器,因为它会非常消耗资源。

总结

既然,在MySQL内部创建触发器,会使得表的执行效率大大降低,我们又如何去监控我们的表操作数据呢?答案是,我们可以使用后台代码,比如python、java,通过连接数据库,实现对数据的行为进行监控,达到我们日志的监控(表的操作)。

举一个简单的例子,目前某学校使用的教务管理系统是采用传统的数据库——mysql,现在老师将学生的成绩统一上传到了后台,但是发现有一位同学的成绩出现了错误,于是它就修改了该同学的数据,这个时候专门的记录操作的表就会记录下该老师的操作行为。

到此这篇关于MySQL触发器自动智能化的数据维护的文章就介绍到这了,更多相关MySQL触发器 内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • MySQL数据库触发器从小白到精通

    这里是MYSQL成圣之路  先了解一下触发器,再来讨论是否能完全代替外键 什么是触发器? 概念:触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行.触发器经常用于加强数据的完整性约束和业务规则等. 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据

  • MySQL事件与触发器专题精炼

    目录 了解触发器和事件(定时器) 什么是触发器? 什么是事件(定时器)? 触发器和事件(定时器)的区别 创建触发器和事件(定时器) 创建触发器 创建事件(定时器) 对触发器和时间(定时器)的操作 查看当前数据库下的触发器和定时器 删除定时器和触发器 这里是MYSQL成圣之路  了解触发器和事件(定时器) 什么是触发器? 概念: 触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启

  • MySQL数据库 触发器 trigger

    目录 一.基本概念 1.作用 2.触发器的优缺点 2.1.优点 2.2.缺点 二.创建触发器 1.基本语法 2.触发对象 3.触发时机 4.触发事件 5.注意事项 需求: 三.查看触发器 四.触发触发器 五.删除触发器 六.触发器的应用 6.完善 2.优化 一.基本概念 触发器是一种特殊类型的存储过程,触发器通过事件进行触发而被执行 触发器 trigger 和js事件类似 1.作用 写入数据表前,强制检验或转换数据(保证数据安全) 触发器发生错误时,异动的结果会被撤销(事务安全) 部分数据库管理

  • mysql触发器trigger实例详解

    MySQL好像从5.0.2版本就开始支持触发器的功能了,本次博客就来介绍一下触发器,首先还是谈下概念性的东西吧: 什么是触发器 触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合.触发器的这种特性可以协助应用在数据库端确保数据的完整性. 举个例子,比如你现在有两个表[用户表]和[日志表],当一个用户被创建的时候,就需要在日志表中插入创建的log日志,如果在不使用触发器的情况下,你需要编写程序语言逻辑才能实现,但是如果你定义了一个触发器,触发器的作用就是当你在用户表中

  • MySQL触发器的使用和优缺点介绍

    目录 前言 1. 触发器概述 2. 触发器的创建 2.1 创建触发器语法 2.2 代码举例 3. 查看.删除触发器 3.1 查看触发器 3.2 删除触发器 4. 触发器的优缺点 4.1 优点 4.2 缺点 4.3 注意点 前言 在实际开发中,我们经常会遇到这样的情况:有 2 个或者多个相互关联的表,如 商品信息和库存信息分别存放在2个不同的数据表中,我们在添加一条新商品记录的时候,为了保证数据的完整性,必须同时在库存表中添加一条库存记录. 这样一来,我们就必须把这两个关联的操作步骤写到程序里面,

  • MySQL触发器的使用详解

    目录 1.为什么需要触发器 2.触发器概述 3.触发器的创建 3.1语法 3.2 案例演示 4.查看触发器 5.删除触发器 总结 1.为什么需要触发器 有一些表是互相关联的,比如说商品表和库存表,我们对商品表的数据进行操作,那么对应的库存表还得发生变化,这样才可以保证数据的完整.如果我们是自己手动维护的话,比较麻烦. 这个时候我们可以使用触发器,创建一个触发器,让商品信息数据的插入操作自动触发库存数据的插入操作等,这样我们就不需要担心因为忘记添加库存数据而导致数据丢失了. 2.触发器概述 MyS

  • MySQL触发器的使用

    触发器可以在执行语句前或执行后触发其他 SQL 代码运行.触发器可以读取触发语句改变了哪些数据,但是没有返回值.因此可以使用触发器加强业务逻辑的约束而不需要在应用程序写对应的代码. 从上述描述可以看到,触发器可以简化应用程序的逻辑并且可以提升性能,这是因为使用触发器减少了应用程序和服务端的交互次数.同时,触发器有助于完成自动更新归一化和统计数据.例如,我们可以使用触发器自动统计交易订单总金额,订单数及平均客单价. 然而,MySQL 的触发器的应用场合也十分有限,如果你使用过其他数据库产品的触发器

  • Mysql存储过程、触发器、事件调度器使用入门指南

    目录 一.存储过程的简单使用 二.存储过程中的变量 三.变量的作用域 四.存储过程参数 五.逻辑控制语句 1.条件语句 2.循环语句 3.case分支 六.游标 七.自定义函数 八.触发器 九.事件 存储过程(Stored Procedure)是一种在数据库中存储复杂程序的数据库对象.为了完成特定功能的SQL语句集,经过编译创建并保存在数据库中. 一.存储过程的简单使用 创建存储过程 create procedure test() begin select * from users; end;

  • MySQL触发器自动智能化的数据维护

    目录 触发器介绍 触发器的特性 触发器语法 数据准备 创建触发器 触发器——执行多个触发语句 New Old 操作 查看触发器 删除触发器 总结 触发器介绍 触发器,就是一种特殊的存储过程.触发器和存储过程一样是一个能够完成特定功能.存储在数据库服务器上的SQL片段,但是触发器无需调用,当对数据库表中的数据执行DML操作时自动触发这个SQL片段的执行,无需手动条用. 在MySQL中,只有执行insert,delete,update操作时才能触发触发器的执行 触发器的这种特性可以协助应用在数据库端

  • 用mysql触发器自动更新memcache的实现代码

    mysql 5.1支持触发器以及自定义函数接口(UDF)的特性,如果配合libmemcache以及Memcached Functions for MySQL,就能够实现memcache的自动更新.简单记录一下安装测试步骤. 安装步骤 安装memcached,这个步骤很简单,随处可见 安装mysql server 5.1RC,安装办法也很大众,不废话了 编译libmemcached,解压后安装即可./configure; make; make install 编译Memcached Functio

  • MYSQL如何自动为查询数据的结果编上序号详解

    前言 其实自己之前没遇到过这种在查询时给结果编号的情况,是同事打算跳槽,面试回来问到这种情况才想到去研究,以下以单表查询为例分析下: SQL: SELECT (@i:=@i+1) i,user_id,user_name FROM `dt_user_all_orders`, (SELECT @i:=0) as i WHERE user_name='qqqqqqqqqq' LIMIT 0,10; 结果: 如果需要分组后再进行序号显示: SELECT drug_productor,@y:=@y+1 a

  • MySQL触发器运用于迁移和同步数据的实例教程

    1.迁移数据 进行数据库移植,SQL Server=>MySQL.SQL Server上有如下的Trigger SET QUOTED_IDENTIFIER ON GO SET ANSI_NULLS ON GO ALTER TRIGGER [trg_risks] ON dbo.projectrisk FOR INSERT, UPDATE AS BEGIN UPDATE projectrisk SET classification = case when calc>= 9 then 3 when

  • Python保存dict字典类型数据到Mysql并自动创建表与列

    字典是另一种可变容器模型,且可存储任意类型对象,主要是工具类, 接下来使用pymysql来创建表与SQL 下面来看看示例代码: import pymysql class UseMysql(object):     def __init__(self, user, passwd, db, host="127.0.0.1", port=3306):         self.db = db         self.conn = pymysql.connect(             h

  • MySQL自动为查询数据结果加序号

    目录 数据表 MySQL给查询加序号 解释说明 相关知识点 数据表 DROP TABLE IF EXISTS tb_score; CREATE TABLE tb_score( id INT(11) NOT NULL auto_increment, userid VARCHAR(20) NOT NULL COMMENT '用户id', subject VARCHAR(20) COMMENT '科目', score DOUBLE COMMENT '成绩', PRIMARY KEY(id) )ENGI

  • MySQL数据库使用mysqldump导出数据详解

    mysqldump是mysql用于转存储数据库的客户端程序.它主要产生一系列的SQL语句,可以封装到文件,该文件包含有所有重建您的数据库所需要的 SQL命令如CREATE DATABASE,CREATE TABLE,INSERT等等.可以用来实现轻量级的快速迁移或恢复数据库.是mysql数据库实现逻辑备份的一种方式. 在日常维护工作当中经常会需要对数据进行导出操作,而mysqldump是导出数据过程中使用非常频繁的一个工具:它自带的功能参数非常多,文章中会列举出一些常用的操作,在文章末尾会将所有

随机推荐