mysql触发器怎么写

触发器是与 mysql 数据表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性。

mysql触发器怎么写

语法格式如下:

CREATE  ON  FOR EACH Row

语法说明如下。

1) 触发器名

触发器的名称,触发器在当前数据库中必须具有唯一的名称。如果要在某个特定数据库中创建,名称前面应该加上数据库的名称。

2) INSERT | UPDATE | DELETE

触发事件,用于指定激活触发器的语句的种类。

注意:三种触发器的执行时间如下。INSERT:将新行插入表时激活触发器。例如,INSERT 的 BEFORE 触发器不仅能被 MySQL 的 INSERT 语句激活,也能被 LOAD DATA 语句激活。DELETE: 从表中删除某一行数据时激活触发器,例如 DELETE 和 REPLACE 语句。UPDATE:更改表中某一行数据时激活触发器,例如 UPDATE 语句。

3) BEFORE | AFTER

BEFORE 和 AFTER,触发器被触发的时刻,表示触发器是在激活它的语句之前或之后触发。若希望验证新数据是否满足条件,则使用 BEFORE 选项;若希望在激活触发器的语句执行之后完成几个或更多的改变,则通常使用 AFTER 选项。

4) 表名

与触发器相关联的表名,此表必须是永久性表,不能将触发器与临时表或视图关联起来。在该表上触发事件发生时才会激活触发器。同一个表不能拥有两个具有相同触发时刻和事件的触发器。例如,对于一张数据表,不能同时有两个 BEFORE UPDATE 触发器,但可以有一个 BEFORE UPDATE 触发器和一个 BEFORE INSERT 触发器,或一个 BEFORE UPDATE 触发器和一个 AFTER UPDATE 触发器。

5) 触发器主体

触发器动作主体,包含触发器激活时将要执行的 MySQL 语句。如果要执行多个语句,可使用 BEGIN…END 复合语句结构。

牛NIUCMS本地O2O系统 牛NIUCMS本地O2O系统

牛NIUCMS本地O2O系统是一个以php+mysql进行开发的o2o网站系统。NIUCMS是一款强大的网站管理系统。支持智慧城市、智慧小区、智慧乡村、本地生活门户、本地O2O平台的构建。请注意以下几点:1、这套源码必须要服务器支持伪静态,是支持.htaccess规则的伪静态,一般Apache服务器支持,别搞的下载回去以后说什么缺 少文件,其实源码并非缺少文件。2、这套源码请在php 5.4环境下

牛NIUCMS本地O2O系统 0 查看详情 牛NIUCMS本地O2O系统

6) FOR EACH ROW

一般是指行级触发,对于受触发事件影响的每一行都要激活触发器的动作。例如,使用 INSERT 语句向某个表中插入多行数据时,触发器会对每一行数据的插入都执行相应的触发器动作。

注意:每个表都支持 INSERT、UPDATE 和 DELETE 的 BEFORE 与 AFTER,因此每个表最多支持 6 个触发器。每个表的每个事件每次只允许有一个触发器。单一触发器不能与多个事件或多个表关联。

另外,在 MySQL 中,若需要查看数据库中已有的触发器,则可以使用 SHOW TRIGGERS 语句。

例子:

BEGIN    IF new.state  in ('2','3')  then    INSERT INTO `userservice`.`ehome_us_green_examine` (modifydate,modifyuser,brancCode,stateDescription,state,userID,fromSystemkey,applydate,makeHospitalName,illnessName,userName,rightsholderName,tranno) VALUES ( sysdate(), 'manage', old.brancCode, old.stateDescription, new.state, '', old.fromSystemkey, old.applydate,old.makeHospitalName,old.illnessName,old.userName,old.rightsholderName, old.tranno);END IF;  END

这个触发器比较简单,

1、BEGIN到END,之间是对数据库的操作

2、IF到END IF之间是判断,你想的对,就是如果。。。的意思

3、new.state  in (‘2′,’3’) 这句的意思是:该表的字段state为(2或者3)的时候  

4、执行下面的插入语句,new为新值,old是原来的值(如old.userName就是原来的这个字段的值)

5、整个触发器翻译成白话就是,如果该表的state变成2或者3的时候,执行下面的插入语句

备注:那么触发器是发生在状态变化之前还是之后呢?选Before或者After,顾名思义!

以上就是mysql触发器怎么写的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1037558.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 04:09:01
下一篇 2025年12月2日 04:09:22

相关推荐

  • C++ STL核心组件有哪些 容器算法迭代器概览

    C++ STL的核心组件是容器、算法和迭代器。容器用于存储数据,算法用于处理数据,迭代器则作为连接两者的桥梁,三者通过泛型编程和关注点分离实现高效、灵活的代码复用与高性能。 C++ STL的核心组件主要就是容器、算法和迭代器这三大块。它们协同工作,为我们处理数据提供了强大且灵活的工具集,让开发者能够…

    2025年12月18日
    000
  • 模板参数自动推导规则 构造函数模板参数推导

    构造函数模板参数推导失效常见于显式指定模板参数、隐式类型转换、多个构造函数模板冲突、参数依赖复杂、initializer_list使用不当、完美转发失败、成员变量影响或编译器bug;可通过显式转换、enable_if约束、辅助函数、简化逻辑、C++20 Concepts或检查错误信息解决;其与类模板…

    2025年12月18日
    000
  • 工厂模式在C++中怎样应用 简单工厂与抽象工厂对比

    简单工厂通过参数决定创建何种产品,适用于产品少且变化少的场景;抽象工厂则通过接口创建相关产品族,支持扩展而不修改代码,适合复杂系统。 工厂模式在C++中主要用于解耦对象的创建与使用,提升代码的可维护性和扩展性。根据复杂度和应用场景的不同,常见的有简单工厂和抽象工厂两种形式。它们都能实现对象的动态创建…

    2025年12月18日
    000
  • 内存映射文件怎么用 大文件高效访问技术

    %ignore_a_1%通过将文件直接映射到进程虚拟内存,使程序像访问内存一样操作文件,避免传统I/O的数据复制和频繁系统调用,提升大文件随机访问效率。其核心优势在于消除用户态与内核态数据拷贝、利用操作系统页面管理机制实现按需加载和预读优化,并简化编程模型。在Windows使用CreateFileM…

    2025年12月18日
    000
  • 结构体对齐方式如何影响性能 不同对齐方式下的内存访问速度测试

    结构体对齐方式确实会影响性能,尤其是在内存访问效率方面。1. 结构体对齐是指编译器通过插入填充字节使每个成员变量位于其对齐要求的地址上,以提高访问效率;2. 对齐不当可能导致未对齐访问,从而在某些平台(如arm)上引发异常或在x86/x64上降低性能;3. 测试对齐影响可通过定义自然对齐与强制紧凑的…

    2025年12月18日 好文分享
    000
  • C++标准库算法如何加速 自定义迭代器与并行化改造方法

    要提升c++++标准库算法性能,可从优化自定义迭代器、利用并行策略及手动多线程处理入手。1. 自定义迭代器应轻量实现operator*()和operator++(),尽量支持随机访问以启用更高效算法;2. c++17以上可用执行策略std::execution::par进行并行化,但需确保迭代器适合…

    2025年12月18日 好文分享
    000
  • 如何优化C++的内存局部性 缓存友好数据结构设计原则

    c++++内存局部性优化通过设计缓存友好的数据结构提升程序性能。1. 数据应尽量连续存储,如使用数组而非链表;2. 结构体成员应按访问频率排序,减少跨缓存行访问;3. 避免指针跳转以降低随机访问;4. 使用填充技术防止伪共享;5. 多线程中优先访问私有数据并合理使用锁;6. 选择std::vecto…

    2025年12月18日 好文分享
    000
  • 异常规格说明deprecated了吗 noexcept替代方案指南

    异常规格说明中的动态异常规格已被弃用,c++++11引入noexcept作为替代。1. 动态异常规格因运行时开销、性能影响、维护困难和不安全性被逐步淘汰,c++17正式移除。2. noexcept在编译期确定是否抛出异常,提升性能与安全性,语法为void func() noexcept;或noexc…

    2025年12月18日
    000
  • 如何调试智能指针的内存问题 使用工具检测智能指针的内存泄漏

    是的,智能指针可能因循环引用、错误资源管理或与裸指针混用等原因导致内存泄漏。1. 循环引用:如std::shared_ptr相互持有,造成引用计数无法归零,对象无法析构;2. 自定义删除器错误:未正确释放资源或误删其他资源;3. 与裸指针混用:可能导致双重释放或内存损坏;4. 非内存资源管理不当:文…

    2025年12月18日 好文分享
    000
  • 怎样编写C++的嵌套类 内部类与外部类的访问权限控制

    c++++中嵌套类的访问权限控制可通过友元机制实现。1. 嵌套类默认无法直接访问外部类成员,需将嵌套类声明为外部类的友元以访问其私有成员;2. 外部类若要访问嵌套类私有成员,则需在嵌套类中将外部类声明为友元;3. 嵌套类默认是私有的,外部无法直接访问,需显式指定public权限;4. 嵌套类不继承外…

    2025年12月18日 好文分享
    000
  • 内存访问冲突怎么调试 地址检查工具使用指南

    调试内存访问冲突时,我会首先启用addresssanitizer(asan)#%#$#%@%@%$#%$#%#%#$%@_20dc++e2c6fa909a5cd62526615fe2788a,因为它能高效精准地定位越界访问、使用已释放内存、双重释放等问题,通过编译时插桩在运行时捕获非法内存操作,输出…

    2025年12月18日
    000
  • C++中如何安全地传递对象所有权 移动语义与智能指针结合使用

    在c++++中安全传递对象所有权需使用移动语义和智能指针。1. 移动语义通过右值引用和std::move实现资源转移,避免深拷贝并确保源对象处于有效但未指定状态;2. 智能指针管理资源生命周期,其中std::unique_ptr实现独占所有权,只能通过std::move转移所有权;3. std::s…

    2025年12月18日 好文分享
    000
  • C++异常处理与SEH有何区别 Windows结构化异常处理对比

    c++++异常处理和windows seh的主要区别在于机制、使用场景和实现方式。1. c++异常是语言级机制,适用于逻辑错误处理,依赖try/catch/throw,跨平台兼容;2. seh是系统级机制,用于底层异常如硬件错误,依赖windows api,语法为__try/__except;3. …

    2025年12月18日 好文分享
    000
  • 模板惰性实例化是什么 理解模板代码生成时机

    模板惰性实例化指编译器仅在模板真正被使用时才生成具体代码,从而优化编译时间与可执行文件大小。1. 显式实例化通过 template 声明强制生成代码;2. 隐式实例化由编译器自动完成;3. 未使用的模板不会生成代码;4. 链接错误可通过头文件定义或显式实例化解决;5. 模板元编程用于编译时计算与代码…

    2025年12月18日 好文分享
    000
  • 怎样实现STL式的泛型编程 概念约束和模板元编程结合

    实现stl式的泛型编程需结合概念约束与模板元编程。1. 使用concepts明确接口约束,通过显式声明类型要求提升代码可读性和安全性,如定义addable概念限制加法操作支持。2. 利用tmp进行类型判断与选择,借助std::is_integral_v、if constexpr等机制实现编译期分支和…

    2025年12月18日 好文分享
    000
  • C++11的enum class有什么改进 强类型枚举的优势解析

    c++++11引入enum class主要为解决传统enum的类型安全和命名空间污染问题。其核心改进包括:1. 强类型机制,禁止枚举值隐式转换为整数,需显式转换(如static_cast),防止意外运算;2. 作用域限制,枚举值仅在枚举类内部可见,避免命名冲突;3. 可指定底层类型(如uint8_t…

    2025年12月18日 好文分享
    000
  • 怎样在结构体中包含另一个结构体 嵌套结构体的设计与访问

    在c++/c++中,结构体嵌套是通过将一个结构体作为另一个结构体的成员来实现的。1. 定义内部结构体如struct point { int x; int y; };;2. 在外部结构体中声明内部结构体类型的成员如point topleft;和point bottomright;;3. 通过点运算符.…

    2025年12月18日 好文分享
    000
  • C++备忘录模式如何实现对象状态保存 序列化与恢复机制

    备忘录模式是一种行为型设计模式,其核心在于在不破坏封装性的前提下捕获并外部化对象内部状态,以便之后可恢复该状态。1. 它包含三个核心角色:发起人(originator)负责创建和恢复状态;备忘录(memento)存储状态且对外隐藏实现细节;管理者(c++aretaker)保存备忘录但不查看其内容。2…

    2025年12月18日 好文分享
    000
  • 如何判断指针是否指向数组元素 标准库提供的边界检查方法

    判断指针是否指向数组元素没有标准方法,但可通过以下方式实现:1.手动计算范围:通过比较指针是否在数组起始地址与结束地址之间判断;2.使用标准库容器:如std::vector或std::array结合size()函数进行边界检查;3.借助第三方工具:如addresssanitizer、valgrind…

    2025年12月18日 好文分享
    000
  • 概念(concept)如何简化模板 约束模板参数要求新语法

    c++++20的“概念”(concepts)通过显式声明类型约束,解决了模板编程中晦涩错误信息、隐式契约和复杂sfinae技巧等痛点。1. 它提供清晰编译时检查,使错误信息更精准;2. 强制模板接口显式化,提升代码可读性与维护性;3. 简化元编程,替代复杂的sfinae机制;4. 支持组合逻辑约束,…

    2025年12月18日 好文分享
    000

发表回复

登录后才能评论
关注微信