首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL触发器的使用

触发器触发器的使用场景以及相应版本: 触发器可以使用的MySQL版本: 版本:MySQL5以上 使用场景例子: 每当增加一个顾客到某个数据库表时,都检查其电话号码格式是否正确,州的缩写是否为大写 每当订购一个产品时...,都从库存数量减去订购的数量 无论何时删除一行,都在某个存档表中保留一个副本 即:在某个表发生更改时自动处理。...触发事件: insert update delete 删除触发器: -- 删除触发器 DROP TRIGGER newproduct; INSERT触发器: insert触发器在insert语句执行之前或者之后执行...: drop TRIGGER neworder; 删除触发器。...: 在DELETE触发器在delete语句执行之前或之后执行: 在delete触发器代码内,可以引用OLD的虚拟表,访问被删除的行; OLD的值全部都是只读,不能更新 例子: 使用old保存将要被删除的行到一个存档表

3.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql怎么创建,删除,查看索引?

    mysql是一个开源的应用非常广泛的数据库。mysql里面的索引能利用利用指针,能够大大提高查询效率。特别是当数据量非常大,查询涉及多个表时,使用索引往往能使查询速度加快成千上万倍。...那么,怎么创建索引呢?...图中数123就是对应普通索引,主键索引,和唯一索引 alter table 表名 add index/unique/primary key (索引名); 第三步,表里面已经有索引了,要怎么查看呢...keys from table;如图: show index from 表名; show keys from 表名; 第四步,有时候索引太多,会引起增删改查的性能,所以可以创建就可以删除...,出现了错误,说不能发现索引名,是因为在第一次的时候已经删除了,所以,此索引名已经不存在了,如图 第六步,再次查询索引,是否有没有删除成功,重复第三步的命令,结果如图,说明已经删除

    10.3K20

    MySQL触发器

    MySQL触发器是一种可以在特定数据库事件发生时自动执行的程序。当触发器与特定表关联时,当在该表插入、更新或删除行时,触发器将自动执行相应的操作。...MySQL触发器提供了一种方便的方式来实现数据库自动化和增强数据完整性。创建触发器MySQL触发器有两种类型:BEFORE和AFTER触发器。...BEFORE触发器在插入、更新或删除行之前执行,而AFTER触发器在执行这些操作之后执行。...“BEFORE INSERT OR UPDATE OR DELETE”指定了在插入、更新或删除行之前触发触发器。“FOR EACH ROW”是必需的,指定触发器将为每个插入、更新或删除的行执行。...,例如:自动为新插入的行分配ID自动更新相关联的行验证插入、更新或删除操作的完整性

    2.6K40

    MySQL触发器

    目录: 触发器定义 触发器特性 触发器的创建 删除触发器 触发器定义 与表有关的数据对象,在满足某种条件时,被动执行的SQL语句。...|update|delete on 表名 for each row 业务逻辑; 代码实例: 当A表插入数据后,B表也插入一条数据 create trigger trigger_insert after...insert:为触发器的触发条件。 trigger_insert:为触发器名称。 comments:为B表的一个字段名称。...row begin insert ...; update ...; end;$ 代码实例: 在A表插入数据前,B表插入2条数据 DELIMITER $ CREATE TRIGGER trigger_insert_before...new:after|before insert,用于获取将要插入的数据 old:after|before update|delete,用户获取已经修改的或已经删除的数据 删除触发器 语法: drop trigger

    12.6K10

    MySQL触发器

    查看所有触发器 1.3.2. 查看指定的触发器 1.4. 删除触发器 1.5. 触发器执行的顺序 1.6. NEW 和 OLD 1.6.1. 使用方式 1.6.2....注意 MySQL触发器 定义 MySQL触发器和存储过程一样,都是嵌入到MysQL的一段程序,不过触发器不要调用,而是由事件触发的,这些事件包括insert,update,delete语句,如果定义了触发程序...trigger_event:触发事件,取值为insert,update,delete insert :比如Mysql的insert和replace语句就会触发这个事件 update:更新某一行的数据会激发这个事件...: 删除指定数据库触发器 db :数据库的名字 trigger_name :触发器的名字 触发器执行的顺序 我们建立的数据库一般都是InnoDB数据库,其上建立的表是事务性表,也就是事务安全的。...; 在 DELETE型触发器,OLD 用来表示将要或已经被删除的原数据; 使用方式 NEW/OLD.columName : 比如获取更新后的name字段的值 new.name 注意 OLD 是只读的,

    5.1K20

    MySQL触发器

    触发器概述  MySQL从 5 . 0 . 2 版本开始支持触发器MySQL触发器和存储过程一样,都是嵌入到MySQL服务器的一 段程序。...当对数据表的数据执行插入、更新和删除操作,需要自动执行一些数据库逻辑时,可以使用触发器来 实现。...查看、删除触发器  方式1:查看当前数据库的所有触发器的定义 SHOW TRIGGERS 方式2:查看当前数据库某个触发器的定义方式 SHOW CREATE TRIGGER 触发器名 方式3:从系统库...为了解决这个问题,我们就可以使用触发器,规定每当进货单明细表有数据插入、修改和删除的操作 时,自动触发 2 步操作: 1)重新计算进货单明细表的数量合计和金额合计; 2)用第一步中计算出来的值更新进货单头表的合计数量与合计金额...注意点 注意,如果在子表定义了外键约束,并且外键指定了ON UPDATE/DELETE CASCADE/SET NULL子句,此时修改父表被引用的键值或删除父表被引用的记录行时,也会引起子表的修改和删除操作

    3.2K20

    mysql触发器

    现在触发器只支持行级触发,不支持语句级触发,触发器不能更新或覆盖。为了修改一个触发器,必须先删除它,然后再重新创建。...OLD,OLD是在delete触发器中有用的,意思是说我要删除一条数据,但是在触发器要用到之前的那个数据,那么我就可以通过OLD来获取了!...比如我删除了一条数据,里面包含一个email,现在我在触发器的内部sql要用就可以这样子写:OLD.email!...触发器不支持CALL语句。...但是对这部分内容点比较陌生,后面通过触发器关键字解决了这个问题,但是还是需要扩展一下binlog相关的知识点 MySQL的二进制日志binlog可以说是MySQL最重要的日志,它记录了所有的DDL和DML

    6.8K30

    MySQL触发器

    大家好,又见面了,我是全栈君 MySQL在5.0.2版本以上开始支持触发器触发器是有某些带有命令的时间来触发某些操作,这些事件包括insert语句、delete语句、update语句等。...1、创建mysql触发器: (1)创建具有单个执行语句的触发器 create trigger 触发器名称 before | after触发事件 on 表名 for each row 执行语句 before...insert on studentinfo for each row insert into timelog(savetime) values(now()); // 当用户向studentinfo表insert...之前,数据库会自动向timelog插入当前操作的时间 更多:http://hovertree.com/menu/mysql/ (2)创建具有多个执行语句的触发器 create trigger 触发器名称...:是数据库中用于记录触发器信息的数据表; TRIGGER_NAME:用于指定要查看的触发器名称 3、删除触发器 droptrigger 触发器名称; 发布者:全栈程序员栈长,转载请注明出处:https

    4K20

    Mysql触发器

    数据库除了需要定时完成一些任务外,有时我们也想在某些表数据变化时自动执行些操作,这就要用到触发器了 基本语法 -- 删除已有同名触发器 DROP TRIGGER IF EXISTS trigger_name...语句触发; DELETE 型触发器删除某一行时激活触发器,可能通过 DELETE、REPLACE 语句触发。...定义了 NEW 和 OLD,用来表示触发器的所在表,触发了触发器的那一行数据。...具体: 在 INSERT 型触发器,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据; 在 UPDATE 型触发器,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据...; 在 DELETE 型触发器,OLD 用来表示将要或已经被删除的原数据; 使用方法: NEW.columnName (columnName 为相应数据表某一列名) if else declare

    4.5K30

    MySQL触发器

    MySQL,只有执行insert,delete,update操作时才能触发 触发器的执行 触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验 等操作 。...,则先删除 drop trigger if exists trigger_test1;   -- 创建触发器trigger_test1 create trigger trigger_test1 after...update user set password = '888888' where uid = 1; 操作-NEW与OLD 格式 MySQL 定义了 NEW 和 OLD,用来表示触发器的所在表,触发了触发器的那一行数据...show triggers; 操作-删除触发器 -- drop trigger [if exists] trigger_name drop trigger if exists trigger_test1...; 注意事项 1.MYSQL触发器不能对本表进行 insert ,update ,delete 操作,以免递归循环触发 2.尽量少使用触发器,假设触发器触发每次执行1s,insert table 500

    6.4K10

    触发器创建删除等操作

    大家好,又见面了,我是全栈君 一、创建一个简单的触发器 触发器是一种特殊的存储过程,类似于事件函数,SQL Server™ 允许为 INSERT、UPDATE、DELETE 创建触发器,即当在表插入、...二、删除触发器 用查询分析器删除 在查询分析器中使用 drop trigger 触发器名称 来删除触发器。...也可以同时删除多个触发器:drop trigger 触发器名称,触发器名称… 注意:触发器名称是不加引号的。...在删除触发器之前可以先看一下触发器是否存在: if Exists(select name from sysobjects where name=触发器名称 and xtype=’TR’) 用企业管理器删除...在企业管理器,在表上点右键->“所有任务”->“管理触发器”,选中所要删除触发器,然后点击“删除”。

    1.7K20

    MySQL-20】关于触发器,你需要知道这些——>定义(创建&查看&删除) 触发器,将变更日志插入日志表

    前言 大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎!...本章主要内容面向接触过C++的老铁 主要内容含: 一.触发器的介绍&类型 注意:触发器只支持 行级触发器 二.触发器操作的相关语法【创建&查看&删除】 三.定义触发器,完成如下需求 -- 触发器...-- 需求:通过触发器记录 user 表的数据变更日志(user_logs),包含增加,修改 ,删除; -- 准备工作:日志表 user_logs create table user_logs(...show triggers ; -- 删除 drop trigger tb_user_insert_trigger; drop trigger tb_user_update_trigger; drop...update tb_user set profession='会计'where id = 23; update tb_user set profession='会计'where id <= 5; -- 删除数搭触发器

    7810

    MySQL触发器示例

    示例:自动更新相关联的行下面是一个示例触发器,用于自动更新“orders”表删除的“customers”表相关联的订单。...“update_orders”,与“customers”表关联,在每次从“customers”表删除一行时自动执行。...在触发器,我们使用UPDATE语句将“orders”表与被删除的“customers”表相关联的行的“customer_id”列设置为NULL。...在触发器,我们使用IF语句来检查新行的“salary”列的值是否大于等于1000。如果小于1000,则触发器会使用SIGNAL语句引发一个错误,以阻止插入操作的继续进行。...删除触发器删除MySQL触发器,可以使用DROP TRIGGER语句:DROP TRIGGER trigger_name;其中,“trigger_name”是要删除触发器的名称。

    2.4K30
    领券