我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQL触发器定义与使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQL触发器定义与使用

比如:现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据。

CALL sp_add_student( 
'S20170091', '杨艳', '女', '2003-04-09',
15, 'G0206', 89.23, 'T0021'
);

如果有多个学生的数据需要插入,则需要多次调用该存储过程;可否不开发存储过程,在向student表插入(INSERT)数据前,后台自动判断并插入老师数据?

触发器简介

触发器:一种与表操作有关的数据库对象,当触发器所在表上出现指定事件(新增、修改、删除数据)时,将调用该对象,即表的操作事件触发表上的触发器的执行。

触发器的创建及调用

比如:现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据。

触发器的创建:使用关键字CREATE TRIGGER

CREATE TRIGGER tri_add_student BEFORE INSERT
ON student FOR EACH ROW
BEGIN
	IF NOT EXISTS(SELECT 1 FROM teacher WHERE teacher_id = new.teacher_id) THEN
	INSERT INTO teacher(teacher_id) VALUES (new.teacher_id);
END IF;
END;
INSERT INTO student VALUES(
'S20170092', '李文', '女', '2002-11-19',
16, 'G0206', 55.32, 'T0022'
);

触发器的分类及执行顺序

按事件类型分:

  • INSERT触发器;
  • UPDATE触发器;
  • DELETE触发器;

按执行先后分:

  • BEFORE触发器;
  • AFTER触发器;

NEW与OLD:

  • INSERT触发器:NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
  • UPDATE触发器:OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据;
  • DELETE触发器:OLD 用来表示将要或已经被删除的原数据;

触发器执行时的异常情况:

  • 如果 BEFORE 触发器执行失败,SQL 无法正确执行;
  • SQL 执行失败时,AFTER 型触发器不会触发;
  • AFTER 类型的触发器执行失败,SQL 会回滚;

触发器的删除

触发器的删除:使用关键字DROP TRIGGER

如:DROP TRIGGER tri_add_student;

触发器的优缺点

优点:

  • 自动触发,无需调用;
  • 提供了一种检查、保证数据完整性的方法;
  • 与存储过程一样,增强SQL语言的功能和灵活性;

缺点:

  • 开发调试困难;
  • 可移植性差;

到此这篇关于SQL触发器定义与使用的文章就介绍到这了,更多相关SQL触发器内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQL触发器定义与使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SQL触发器定义与使用

目录触发器简介触发器的创建及调用触发器的分类及执行顺序触发器的删除触发器的优缺点比如:现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学
2023-01-05

Mysql触发器怎么定义与使用

这篇“Mysql触发器怎么定义与使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mysql触发器怎么定义与使用”文章吧。一
2023-07-04

Mysql中的触发器定义与使用

目录一、触发器的介绍二、触发器的语法(1)insert触发器(2)update触发器(3)delete触发器一、触发器的介绍触发器是与表有关的数据库对象,指在insert/update/delete 之前或之后,触发并执行触发器中定义的
2022-11-30

MySQL触发器的定义与使用方法详解

MySQL触发器的定义与使用方法详解 MySQL触发器是一种特殊的存储过程,可以在表发生特定事件时自动执行。触发器可以用于实现 数据的自动化处理、数据一致性维护等功能。本文将详细介绍MySQL触发器的定义与使用方法,并提供具体的代码示例。
MySQL触发器的定义与使用方法详解
2024-03-15

SQL SERVER触发器怎么使用

SQL Server触发器可以在数据库中的表上定义,当满足特定条件时,触发器会自动执行一些操作。以下是使用SQL Server触发器的一般步骤:1. 创建触发器:使用CREATE TRIGGER语句创建触发器,指定触发器的名称、触发时机(例
2023-08-18

如何在MySQL中使用Python编写自定义触发器、存储引擎和触发器

如何在MySQL中使用Python编写自定义触发器、存储引擎和触发器触发器(triggers)是MySQL数据库中的一种特殊类型的存储过程。它们与特定的表相关联,并在表的INSERT、UPDATE或DELETE操作时自动触发并执行一些特定的
2023-10-22

如何在MySQL中使用JavaScript编写自定义触发器、存储引擎和触发器

如何在MySQL中使用JavaScript编写自定义触发器、存储引擎和存储过程导读:MySQL是一种广泛使用的关系型数据库管理系统,它使用SQL(结构化查询语言)作为其主要查询语言。然而,MySQL也支持其他编程语言,如JavaScript
2023-10-22

如何在MySQL中使用C#编写自定义触发器、存储引擎和触发器

在MySQL中使用C#编写自定义触发器、存储引擎和触发器,需要使用MySQL的Connector/NET,这是一个用于连接MySQL数据库的.NET驱动程序。下面是一个简单的示例,展示如何使用C#编写MySQL的自定义触发器、存储引擎和触发
2023-10-20

sql触发器的使用有哪些

SQL触发器是数据库中的一种特殊对象,它们可以在数据库中的某个特定事件发生时自动执行一系列的操作。以下是SQL触发器的一些常见使用场景:数据完整性维护:当插入、更新或删除表中的数据时,触发器可用于保持数据的完整性。比如,当插入一条新的订单时
2023-10-25

sql触发器的使用及语法

触发器是一种数据库代码,在特定事件(插入、更新、删除)发生时自动执行。触发器的语法包含触发器名称、表名称和触发时机(before/after)以及事件类型(insert/update/delete)。触发器类型包括 before 和 aft
sql触发器的使用及语法
2024-04-13

如何在MySQL中使用PHP编写自定义存储引擎、触发器和触发器

如何在MySQL中使用PHP编写自定义存储引擎、触发器和函数本指南提供了一个分步过程,说明如何使用PHP在MySQL中创建自定义存储引擎、触发器和函数。它涵盖了每个组件的语法和使用PHP的示例代码。利用这些自定义元素,可以扩展MySQL的功能,优化查询性能,并自动化数据库操作。
如何在MySQL中使用PHP编写自定义存储引擎、触发器和触发器
2024-04-10

如何在MySQL中使用PHP编写自定义触发器、存储引擎和触发器

如何在MySQL中使用PHP编写自定义触发器、存储引擎和触发器引言:MySQL是一个广泛使用的开源关系型数据库管理系统,在数据库开发中,触发器和存储过程是非常重要的概念。本文将重点介绍如何使用PHP编写MySQL中的自定义触发器、存储引擎和
2023-10-22

如何在MySQL中使用PHP编写自定义存储引擎、触发器和触发器

在MySQL中使用PHP编写自定义存储引擎、触发器和函数是不可能的,因为MySQL不支持使用PHP作为存储引擎或触发器的编程语言。MySQL提供了一些内置的存储引擎(如InnoDB、MyISAM等)和触发器(如BEFORE INSERT、A
2023-10-20

SQL触发器的使用及语法

定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。常见的触发器有三种:分别应用于Insert , Update , Delete 事件。我为什么要使用触发器?比如,这么两个

	SQL触发器的使用及语法
2015-02-12

MySQL自定义函数及触发器

这篇文章主要介绍了MySQL自定义函数及触发器,自定义函数是一种对MySQL扩展的途径,其用法与内置的函数相同,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
2022-11-13

编程热搜

目录