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

MySQLMariaDB触发器详解

在MySQL中,一张表只能有一个同时间、同事件的触发器,所以MySQL中不支持基于列的触发器。...在MySQL/MariaDB中,使用old和new表分别表示触发器激活后的新旧表,在SQL Server中使用的是inserted和deleted表,其实它们的意义是等价的。...且无论是before还是after insert触发器都有new表的存在。 在mariadb 10.2.3版本之后,一个表中可以为同一时间、同一事件创建多个触发器(在mysql中不允许)。...TRUNCATE audit; 首先测试下使用on duplicate key update子句插入无重复的记录。注意,emp表的emp_no列具有主键属性,它不允许出现重复值。...在insert into... on duplicate key update语句中,插入没有重复值冲突的记录时,首先判断是否存在before insert触发器,有就触发,触发之后检查约束,发现没有重复值冲突

1.8K20

数据库相关知识总结

因此,每个表最多支持6个触发器(每条INSERT、UPDATE 和DELETE的之前和之后)。...删除触发器 drop trigger trigger_name; INSERT触发器在INSERT语句执行之前或之后执行。...需要知道以下几点: 在INSERT触发器代码内,可引用一个名为NEW的虚拟表,访问被插入的行; 在BEFORE INSERT触发器中,NEW中的值也可以被更新(允许更改被插入的值); 对于AUTO_INCREMENT...列,NEW在INSERT执行之前包含0,在INSERT执行之后包含新的自动生成值。...需要知道以下几点: 在UPDATE触发器代码中,你可以引用一个名为OLD的虚拟表访问以前(UPDATE语句前)的值,引用一个名为NEW的虚拟表访问新更新的值; 在BEFORE UPDATE触发器中,NEW

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

    SQL命令 CREATE TRIGGER(一)

    REFERENCING子句允许指定可用于引用列的别名。引用旧行允许在UPDATE或DELETE触发器期间引用列的旧值。引用新行允许在INSERT或UPDATE触发器期间引用列的新值。...在指定表中插入行时,将执行指定为INSERT的触发器。从指定表中删除行时,将执行指定为DELETE的触发器。在指定表中更新行时,将执行指定为UPDATE的触发器。...可以按任意顺序指定单个触发器事件或以逗号分隔的INSERT、UPDATE或DELETE触发器事件列表。 指定为UPDATE OF的触发器仅在指定表的一行中更新了一个或多个指定列时才执行。...新值是UPDATE或INSERT触发器的触发操作之后的行值。...因此,同样的条款也可以指定为: REFERENCING OLD oldalias NEW newalias 在INSERT之前引用旧值或在DELETE之后引用新值是没有意义的。

    2K30

    MySQL命令,一篇文章替你全部搞定

    新建表(或)数据库 新建数据库:CREATE DATABASE customers; 创建表可以使用CREATE TABLE语句: 有这样一些细节: 允许NULL值,则说明在插入行数据时允许不给出该列的值...,而NOT NULL则表示在插入或者更新该列数据,必须明确给出该列的值; DEFAULT表示该列的默认值,在插入行数据时,若没有给出该列的值就会使用其指定的默认值; PRIMARY KEY用于指定主键,...1.4 更新表 更新表结构信息可以使用ALTER TABLE子句,如为表增加一列:ALTER TABLE vendors ADD vend_name CHAR(20);另外经常用于定义外键,如: 重命名表...,NEW中的值可以被更新;3.对于AUTO_INCREMENT列,NEW在INSERT执行之前包含0,在INSERT执行之后包含新的自定生成值。...有这样一些细节: 使用CREATE TRIGGER来创建触发器; AFTER INSERT表明在插入行数据之后,触发器才会执行特征操作; FOR EACH ROW 表示对插入的每一行数据,触发器都起作用

    2.6K20

    ORACLE触发器具体解释

    REFERENCING 子句说明相关名称,在行触发器的PL/SQL块和WHEN 子句中能够使用相关名称參照当前的新、旧列值,默认的相关名称分别为OLD和NEW。...触发器中不能使用LONG, LONG RAW 类型; l 触发器内能够參照LOB 类型列的列值,但不能通过 :NEW 改动LOB列中的数据; DML触发器基本要点 l 触发时机...问题:当触发器被触发时,要使用被插入、更新或删除的记录中的列值,有时要使用操作前、 后列的值....在改动了主表regions中的region_id之后(AFTER),级联的、自己主动的更新子表countries表中原来在该地区的国家的region_id。...REFERENCING 子句说明相关名称,在行触发器的PL/SQL块和WHEN 子句中能够使用相关名称參照当前的新、旧列值,默认的相关名称分别为OLD和NEW。

    1.2K30

    学习SQLite之路(三)

    列级约束仅适用于列,表级约束被应用到整个表 (1)以下是在 SQLite 中常用的约束 NOT NULL 约束:确保某列不能有 NULL 值。...(1)要点: SQLite 的触发器(Trigger)可以指定在特定的数据库表发生 DELETE、INSERT 或 UPDATE 时触发,或在一个或多个指定表的列发生更新时触发。...WHEN 子句和触发器(Trigger)动作可能访问使用表单 NEW.column-name 和 OLD.column-name 的引用插入、删除或更新的行元素,其中 column-name 是从与触发器关联的表的列的名称...BEFORE 或 AFTER 关键字决定何时执行触发器动作,决定是在关联行的插入、修改或删除之前或者之后执行触发器动作。 当触发器相关联的表删除时,自动删除触发器(Trigger)。...(6)什么情况下要避免使用索引: 索引不应该使用在较小的表上。 索引不应该使用在有频繁的大批量的更新或插入操作的表上。 索引不应该使用在含有大量的 NULL 值的列上。

    3K70

    SQL 语法速成手册

    WHERE 子句中使用,作用是在指定的几个特定值中任选一个值。...BETWEEN 操作符在 WHERE 子句中使用,作用是选取介于某个范围内的值。...约束可以在创建表时规定(通过 CREATE TABLE 语句),或者在表创建之后规定(通过 ALTER TABLE 语句)。 约束类型 NOT NULL - 指示某列不能存储 NULL 值。...可以使用触发器来进行审计跟踪,把修改记录到另外一张表中。 MySQL 不允许在触发器中使用 CALL 语句 ,也就是不能调用存储过程。...; 在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据; 使用方法: NEW.columnName (columnName 为相应数据表某一列名) 创建触发器 提示:为了理解触发器的要点

    17.2K40

    SQL 语法速成手册

    WHERE 子句中使用,作用是在指定的几个特定值中任选一个值。...BETWEEN 操作符在 WHERE 子句中使用,作用是选取介于某个范围内的值。...约束可以在创建表时规定(通过 CREATE TABLE 语句),或者在表创建之后规定(通过 ALTER TABLE 语句)。 约束类型 NOT NULL - 指示某列不能存储 NULL 值。...可以使用触发器来进行审计跟踪,把修改记录到另外一张表中。 MySQL 不允许在触发器中使用 CALL 语句 ,也就是不能调用存储过程。...; 在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据; 使用方法: NEW.columnName (columnName 为相应数据表某一列名) 创建触发器 提示:为了理解触发器的要点

    16.9K20

    MySQL见闻录 - 入门之旅(四)

    如果在执行INSERT、REPLACE、 UPDATE、 LOAD DATA和ALTER TABLE等语句时发生上述转换,MySQL将生成一条警告消息。...在定义完存储程序之后,可以把mysql程序的语句终止符重新定义为分号。...下面的例子在定义一一个存储过程时把mysq1程序的默认分隔符临时改变为$,然后在恢复了mysql程序的默认分隔符之后执行了那个存储过程: ?...7、触发器 触发器是与特定数据表相关联的存储过程,当相应的数据表被INSERT、DELETE 或UPDATE语句修改时,触发器将自动执行。触发器可以被设置成在这几种语句处理每个数据行之前或之后触发。...在触发器的定义里需要表明它将由哪种语句(INSERT、UPDATE或DELETE)触发,是在数据行被修改之前还是之后被触发。

    1K10

    【DB笔试面试448】Oracle中有哪几类触发器?

    l REFERENCING子句说明相关名称,在行级触发器的PL/SQL块和WHEN子句中可以使用相关名称参照当前的新、旧列值,默认的相关名称分别为OLD和NEW。...l 触发器内不能通过:NEW修改LOB列中的数据 l 触发器最多可以嵌套32层 当触发器被触发时,要使用被插入、更新或删除的记录中的列值,有时要使用操作前或操作后列的值,这个时候可以使用:NEW或者:...其中,:NEW表示操作完成后列的值,而:OLD表示操作完成前列的值,如下表所示: 特性 INSERT UPDATE DELETE :OLD NULL 修改前的值 删除前的值 :NEW 插入的值 修改后的值...语句更新数据库对象之前、之后触发 DDL BEFORE、AFTER 在执行大多数DDL语句之前、之后触发 GRANT BEFORE、AFTER 执行GRANT语句授予权限之前、之后触发 REVOKE BEFORE...l 在触发器的执行部分只能使用DML语句(例如SELECT、INSERT、UPDATE、DELETE等),不能使用DDL语句(例如CREATE、ALTER、DROP等)。

    2.1K10

    数据库对象

    对单属性构成有两种说明方法: 列级约束 CREATE TABLE student( # 在列级定义主键 id int not NULL UNIQUE PRIMARY KEY, `...属性上的约束具体由三种 列值非空(NOT NULL) 列值唯一(UNIQUE) 检查列值是否满足某一条件表达式(CHECK短语) CREATE TABLE student( # 非空...官方解释: 触发器(Trigger)是一种数据库对象,用于在特定的数据库操作(如INSERT、UPDATE或DELETE操作)执行之前或之后自动执行一些指定的动作。...trigger_name:触发器的名称,应该唯一且易于识别。 {BEFORE | AFTER}:指定触发器在相应的数据库操作之前或之后执行。...例如,以下是一个在表employees上创建一个在INSERT操作之前触发的触发器的示例: CREATE TRIGGER before_insert_employee -- 创建触发器 BEFORE INSERT

    13010

    数据库学习笔记(三)

    Student ( Sno char(9) primary key, # 在列级定义主码 Sname char(20) not null, Ssex char(2) ); create table...用户定义的完整性:针对某一具体应用的数据必须满足的语义要求 1.4.1 属性上的约束条件 建表时定义属性上的约束条件 列值非空(not null) 列值唯一(unique) 检查列值是否满足一个条件表达式...primary key(Sno, Cno) # Sno、Cno、Grade属性不允许取空值 ) 列值唯一 create table DEPT ( Deptno numeric(2), Dname...char(9) unique not null, # 要求Dname列值唯一,并且不能取空值 primary key(Deptno) ) 用 check 短语指定列值应该满足的条件 create...OldTuple new row as NewTuple # 把引发事件之后的值改名为NewTuple for each row # 行级触发器,即每执行一次Grade的更新,下面的规则就会执行一次

    71220

    PLSQL --> DML 触发器

    INSTEAD OF 触发器 在ORACLE里,对于简单视图,可以直接使用DML进行操作,而复杂视图则不能直接使用DML,因此INSTEAD OF 触发器应运而生。...在行触发器的PL/SQL块和WHEN 子句中可以使用相关名称参照当前的新,旧列值,默认的相关名称分别为OLD和NEW。...4.NEW、OLD 限定符的使用 使用被插入、更新或删除的记录中的列值,可以使用NEW和OLD限定符来表示 :old 修饰符访问操作完成前列的值 :new 修饰符访问操作完成后列的值 限定符 INSERT...--更新了行,当audit_table_emp表中仅仅记录一次,UPD的值增加到 scott@ORCL> select * from audit_table_emp; NAME INS UPD DEL...CREATE TABLE audit_emp_change --创建audit_emp_change存放emp 表sal列被更新前后的值 ( name VARCHAR2(10), oldsal

    1.5K30

    Java面试手册:数据库 ④

    当INSERT、UPDATE 或 DELETE 语句修改指定表或视图中的数据时,可以使用 DML 触发器。...通常说的触发器就是DML触发器:DML 触发器在 INSERT、UPDATE 和 DELETE 语句上操作,并且有助于在表或视图中修改数据时强制业务规则,扩展数据完整性。...即在操作之前触发 后置触发器 :对目标包进行 更新,插入,删除 操作之后执行 before delete 触发器: 在对目标表删除之前执行 insted of 触发器: 对复杂的视图 执行插入...与 CHECK 约束不同,触发器可以引用其它表中的列。例如,触发器可以使用另一个表中的 SELECT 比较插入或更新的数据,以及执行其它操作,如修改数据或显示用户定义错误信息。...别名 as 什么情况下使用 计算字段 拼接:sqlserver用“+”,Oracle用“||”,MySQL用“concat()” 出去重复记录:distinct 一个列可能有多个重复的值,如果只想要不同的值

    1.3K30

    SQL语法速成手册,建议收藏!

    WHERE 子句中使用,作用是在指定的几个特定值中任选一个值。...BETWEEN 操作符在 WHERE 子句中使用,作用是选取介于某个范围内的值。...约束可以在创建表时规定(通过 CREATE TABLE 语句),或者在表创建之后规定(通过 ALTER TABLE 语句)。 约束类型 NOT NULL - 指示某列不能存储 NULL 值。...可以使用触发器来进行审计跟踪,把修改记录到另外一张表中。 MySQL 不允许在触发器中使用 CALL 语句 ,也就是不能调用存储过程。...; 在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据; 使用方法:NEW.columnName (columnName 为相应数据表某一列名) 创建触发器 提示:为了理解触发器的要点

    8.1K30

    Oracle-trigger触发器解读

    ,前触发是在执行触发事件之前触发当前所创建的触发器,后触发是在执行触发事件之后触发当前所创建的触发器。...REFERENCING 子句说明相关名称,在行触发器的PL/SQL块和WHEN 子句中可以使用相关名称参照当前的新、旧列值,默认的相关名称分别为OLD和NEW。...类型; 触发器内可以参照LOB 类型列的列值,但不能通过 :NEW 修改LOB列中的数据; DML触发器基本要点 触发时机:指定触发器的触发时间。...需要for each row /** 涨后的薪水不能低于涨前的薪水 1 :old 和 :new 代表同一条记录 2 :old 代表操作该行之前,这一行的值 :new 代表操作该行之后,这一行的值...在修改了主表regions中的region_id之后(AFTER),级联的、自动的更新子表countries表中原来在该地区的国家的region_id。

    1.1K30

    Oracle触发器-imooc

    ,后触发是在执行事件之后触发。...块和WHEN 子句中可以使用相关名称参照当前的新、旧列值,默认的相关名称分别为:old和:new。...触发器的类型 行触发器要求当一个DML语句操作影响数据库中的多行数据时,对于其中的每个数据行,只要它们符合触发约束条件,均激活一次触发器; 在行级触发器中,使用:old 和:new 伪记录变量,识别值的状态...类型; 触发器内可以参照LOB 类型列的列值,但不能通过 :NEW 修改LOB列中的数据; 二、触发器应用 2-1触发器应用一 复杂的安全性检查 禁止在非工作时间插入数据 在命令行查询时间 SQL...数据的备份和同步 使用触发器实现对emp的备份(给员工涨完工资后自动更新新的数据到备份表中) 第一步 创建emp的备份表 create table emp_bak as select * from

    1.3K20

    MySQL中触发器的使用

    触发事件: insert update delete 删除触发器: -- 删除触发器 DROP TRIGGER newproduct; INSERT触发器: insert触发器在insert语句执行之前或者之后执行...可以引用一个名为NEW的虚拟表,访问被插入的行; 在before insert触发器中,NEW中的值也可以被更新(允许更改被插入的值) 对于AUTO_INCREMENT列,NEW在insert执行之前包含...0,在insert执行之后包含新的自动生成值 例子:插入一个新的订单时,生成一个新的订单号保存到order_num CREATE TRIGGER neworder AFTER INSERT ON orders...: 在update触发器的代码中,可以引用一个名为OLD的虚拟表访问以前的值,即:update未执行前的值,还可以引用一个名为NEW的虚拟表访问新更新的值; 在before update触发器中,NEW...: 在DELETE触发器在delete语句执行之前或之后执行: 在delete触发器代码内,可以引用OLD的虚拟表,访问被删除的行; OLD中的值全部都是只读,不能更新 例子: 使用old保存将要被删除的行到一个存档表中

    3.3K10

    oracle的行级触发器使用

    行级触发器: 当触发器被触发时,要使用被插入、更新或删除的记录中的列值,有时要使用操作前、后列的值....:NEW 修饰符访问操作完成后列的值 :OLD 修饰符访问操作完成前列的值 例1: 建立一个触发器, 当职工表 emp 表被删除一条记录时,把被删除记录写到职工表删除日志表中去。...emp_his; DROP TRIGGER del_emp; 例2:限制对Departments表修改(包括INSERT,DELETE,UPDATE)的时间范围,即不允许在非工作时间修改departments...在修改了主表 regions 中的 region_id 之后( AFTER ),级联的、自动的更新子表 countries 表中原来在该地区的国家的 region_id 。...SET region_id = :new.region_id WHERE region_id = :old.region_id; END ; 例5:在触发器中调用过程。

    1.6K50
    领券