목차
一、语法
二、关于旧的和新创建的列的标识
三、使用范例
데이터 베이스 MySQL 튜토리얼 MySql触发器使用讲解_MySQL

MySql触发器使用讲解_MySQL

Jun 01, 2016 pm 12:58 PM
방아쇠

触发器(TRIGGER)是由事件来触发某个操作。这些事件包括INSERT语句、UPDATE语句和DELETE语句。当数据库系统执行这些事件时,就会激活触发器执行相应的操作。MySQL从5.0.2版本开始支持触发器。在本文中将讲解的内容包括:

触发器的含义和作用
如何创建触发器
如何查看触发器
如何删除触发器

触发器是由INSERT、UPDATE和DELETE等事件来触发某种特定操作。满足触发器的触发条件时,数据库系统就会执行触发器中定义的程序语句。这样做可以保证某些操作之间的一致性。例如,当学生表中增加了一个学生的信息时,学生的总数就必须同时改变。可以在这里创建一个触发器,每次增加一个学生的记录,就执行一次计算学生总数的操作。这样就可以保证每次增加学生的记录后,学生总数是与记录数是一致的。触发器触发的执行语句可能只有一个,也可能有多个。本节将详细讲解创建触发器的方法。

一、语法

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

MySQL中,创建只有一个执行语句的触发器的基本形式如下:

CREATE TRIGGER 触发器名 BEFORE | AFTER 触发事件
ON 表名 FOR EACH ROW 执行语句
로그인 후 복사
创建有多个执行语句的触发器

MySQL中,触发器触发的执行语句可能有多个。创建有多个执行语句的触发器的基本形式如下:

CREATE TRIGGER 触发器名 BEFORE | AFTER 触发事件
ON 表名 FOR EACH ROW
BEGIN
执行语句列表
END
로그인 후 복사
下面来具体说说语法

1、命名规则

CREATE TRIGGER <触发器名称> <--
{ BEFORE | AFTER }
{ INSERT | UPDATE | DELETE }
ON <表名称>
FOR EACH ROW
BEGIN
<触发器SQL语句>
END
로그인 후 복사

触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和MySQL中其他对象的命名方式基本相象.
2、触发时间: BEFORE | AFTER
触发器有执行的时间设置:INSERT | UPDATE | DELETE
3、触发事件前后
同样也能设定触发的事件:它们可以在执行insert、update或delete的过程中触发。
4.、表
触发器是属于某一个表的:当在这个表上执行插入、
更新或删除操作的时候就导致触发器的激活.
我们不能给同一张表的同一个事件安排两个触发器。
5.、( 步长)触发间隔
触发器的执行间隔:FOR EACH ROW子句通知触发器
每隔一行执行一次动作,而不是对整个表执行一次。
6、 语句
触发器包含所要触发的SQL语句:这里的语句可以是任何合法的语句,
包括复合语句,但是这里的语句受的限制和函数的一样。
Privileges权限
你必须拥有相当大的权限才能创建触发器(CREATE TRIGGER)。如果你已经是Root用户,那么就足够了。这跟SQL的标准有所不同。

二、关于旧的和新创建的列的标识

在触发器的SQL语句中,你可以关联表中的任意列。但你不能仅使用列的名称去标识,那会使系统混淆,因为那里可能会有列的新名(这可能正是你要修改的,你的动作可能正是要修改列名),还有列的旧名存在。因此你必须用这样的语法来标识: "NEW . column_name"或者"OLD . column_name".这样在技术上处理(NEW | OLD . column_name)新和旧的列名属于创建了过渡变量("transition variables")。

对于INSERT语句,只有NEW是合法的;对于DELETE语句,只有OLD才合法;而UPDATE语句可以在和NEW以及OLD同时使用。

三、使用范例

先创建两个表、一个订单表,一个订单时间表

CREATE TABLE T_ORDER(
ORDER_NUM INT PRIMARY KEY,
ORDER_NAME CHAR(10) NOT NULL
);
CREATE TABLE T_ORDER_TIME(
ORDER_NUM INT PRIMARY KEY,
ORDER_TIME TIMESTAMP NOT NULL,
)
로그인 후 복사

1、创建插入时的触发器

CREATE TRIGGER TRI_INSERT
AFTER INSERT ON T_ORDER FOR EACH ROW
BEGIN
INSERT INTO learning.t_order_time(ORDER_NUM,ORDER_TIME) VALUES(NEW.ORDER_NUM,NOW());
END
로그인 후 복사
然后订单表中插入一条数据
INSERT INTO T_ORDER(ORDER_NUM,ORDER_NAME) VALUES(1,&#39;电脑&#39;);
SELECT * FROM t_order;
SELECT * FROM t_order_time;
로그인 후 복사
这是订单表中插入的数据:

\

这是订单时间表中自动插入的数据:

\

2、更新时插入数据

//更新创建触发器
CREATE TRIGGER TRI_UPDATA
BEFORE UPDATE ON T_ORDER FOR EACH ROW
BEGIN
UPDATE  learning.t_order_time SET ORDER_TIME=NOW() WHERE OLD.ORDER_NUM=ORDER_NUM;
END

UPDATE T_ORDER  SET ORDER_NAME=&#39;饼干饼&#39; WHERE ORDER_NUM=1;
SELECT * FROM t_order;
SELECT * FROM t_order_time;
로그인 후 복사

\


可以看到,时间已经更新

3、创建删除触发器

//创建删除触发器
CREATE TRIGGER TRI_DELETE
AFTER DELETE ON T_ORDER FOR EACH ROW
BEGIN
DELETE FROM  learning.t_order_time  WHERE OLD.ORDER_NUM=ORDER_NUM;
END

DELETE FROM  learning.t_order  WHERE ORDER_NUM=1;
SELECT * FROM t_order;
SELECT * FROM t_order_time;
로그인 후 복사
可以看到,数据库中都没有数据了。
\


4、查看触发器

查看触发器是指查看数据库中已存在的触发器的定义、状态和语法等信息。查看触发器的方法包括SHOW TRIGGERS语句和查询information_schema数据库下的triggers表等。本节将详细讲解查看触发器的方法。

MySQL中,可以执行SHOW TRIGGERS语句来查看触发器的基本信息。其基本形式如下:

SHOW TRIGGERS ;

\

MySQL中,所有触发器的定义都存在information_schema数据库下的triggers表中。查询triggers表,可以查看到数据库中所有触发器的详细信息。查询的语句如下:

SELECT * FROM information_schema.triggers;

\

5、删除触发器
DROP TRIGGER 触发器名
로그인 후 복사

6、触发器 与存储过程
触发程序不能调用将数据返回客户端的存储程序,也不能使用采用CALL语句的动态SQL
(允许存储程序通过参数将数据返回触发程序)。
而存储过程 可以接受参数,将结果范围给应用程序

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PowerPoint에서 클릭할 때까지 텍스트를 숨기는 방법 PowerPoint에서 클릭할 때까지 텍스트를 숨기는 방법 Apr 14, 2023 pm 04:40 PM

PowerPoint에서 클릭하기 전에 텍스트를 숨기는 방법 PowerPoint 슬라이드의 아무 곳이나 클릭할 때 텍스트가 나타나도록 하려면 설정이 빠르고 쉽습니다. PowerPoint에서 버튼을 클릭하기 전에 텍스트를 숨기려면: PowerPoint 문서를 열고 삽입 메뉴를 클릭하세요. 새 슬라이드를 클릭하세요. 공백 또는 다른 사전 설정 중 하나를 선택합니다. 삽입 메뉴에서 텍스트 상자를 클릭합니다. 텍스트 상자를 슬라이드로 드래그합니다. 텍스트 상자를 클릭하고 원하는 내용을 입력하세요.

Oracle에 트리거를 추가하는 방법 Oracle에 트리거를 추가하는 방법 Dec 12, 2023 am 10:17 AM

Oracle 데이터베이스에서는 CREATE TRIGGER 문을 사용하여 트리거를 추가할 수 있습니다. 트리거는 데이터베이스 테이블에 하나 이상의 이벤트를 정의하고 이벤트가 발생할 때 자동으로 해당 작업을 수행할 수 있는 데이터베이스 개체입니다.

PHP를 사용하여 MySQL에서 트리거를 작성하는 방법 PHP를 사용하여 MySQL에서 트리거를 작성하는 방법 Sep 21, 2023 am 08:16 AM

PHP를 사용하여 MySQL에서 트리거를 작성하는 방법 MySQL은 일반적으로 사용되는 관계형 데이터베이스 관리 시스템이고 PHP는 널리 사용되는 서버측 스크립팅 언어입니다. PHP를 사용하여 MySQL에서 트리거를 작성하면 자동화된 데이터베이스 작업을 실현하는 데 도움이 될 수 있습니다. 이 기사에서는 PHP를 사용하여 MySQL 트리거를 작성하는 방법을 소개하고 특정 코드 예제를 제공합니다. 시작하기 전에 MySQL과 PHP가 설치되어 있고 해당 데이터베이스 테이블이 생성되었는지 확인하세요. 1. PHP 파일 및 데이터 생성

mysql 트리거는 몇 레벨인가요? mysql 트리거는 몇 레벨인가요? Mar 30, 2023 pm 08:05 PM

MySQL 트리거는 행 수준입니다. SQL 표준에 따르면 트리거는 두 가지 유형으로 나눌 수 있습니다. 1. 수정된 데이터 행마다 한 번씩 활성화되는 행 수준 트리거입니다. 명령문이 100행의 데이터를 삽입하면 트리거가 100번 호출됩니다. 명령문 수준 트리거 트리거는 각 명령문에 대해 한 번씩 활성화됩니다. 100행의 데이터를 삽입하는 명령문은 트리거를 한 번만 호출합니다. MySQL은 준비된 명령문 수준 트리거가 아닌 행 수준 트리거만 지원합니다.

Python을 사용하여 MySQL에서 사용자 정의 트리거를 작성하는 방법 Python을 사용하여 MySQL에서 사용자 정의 트리거를 작성하는 방법 Sep 20, 2023 am 11:04 AM

Python을 사용하여 MySQL에서 사용자 정의 트리거를 작성하는 방법 트리거는 데이터베이스의 테이블에서 자동으로 실행되는 일부 작업을 정의할 수 있는 MySQL의 강력한 기능입니다. Python은 MySQL과 쉽게 상호 작용할 수 있는 간결하고 강력한 프로그래밍 언어입니다. 이 문서에서는 Python을 사용하여 사용자 지정 트리거를 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저, MySQL 데이터베이스를 사용하는 Python의 방식인 PyMySQL 라이브러리를 설치하고 가져와야 합니다.

PHP를 사용하여 MySQL에서 사용자 정의 트리거 및 저장 프로시저를 작성하는 방법 PHP를 사용하여 MySQL에서 사용자 정의 트리거 및 저장 프로시저를 작성하는 방법 Sep 20, 2023 am 11:25 AM

PHP를 사용하여 MySQL에서 사용자 정의 트리거 및 저장 프로시저를 작성하는 방법 소개: 애플리케이션을 개발할 때 데이터 삽입, 업데이트 또는 삭제와 같은 일부 작업을 데이터베이스 수준에서 수행해야 하는 경우가 많습니다. MySQL은 널리 사용되는 관계형 데이터베이스 관리 시스템이고, PHP는 널리 사용되는 서버 측 스크립팅 언어입니다. 이 기사에서는 PHP를 사용하여 MySQL에서 사용자 정의 트리거 및 저장 프로시저를 작성하는 방법을 소개하고 특정 코드 예제를 제공합니다. 1. 트리거와 저장 프로시저 트리거란 무엇입니까(Trigg

MySQL 트리거를 사용하여 데이터 자동 보관을 구현하는 방법 MySQL 트리거를 사용하여 데이터 자동 보관을 구현하는 방법 Aug 02, 2023 am 10:37 AM

MySQL 트리거를 사용하여 데이터 자동 보관을 구현하는 방법 소개: 최신 데이터 관리 분야에서 데이터 자동 보관 및 정리는 중요하고 일반적인 요구 사항입니다. 데이터 양이 증가함에 따라 완전한 기록 데이터를 유지하면 과도한 스토리지 리소스를 차지하고 쿼리 성능이 저하됩니다. MySQL 트리거는 이 요구 사항을 달성하는 효과적인 방법을 제공합니다. 이 기사에서는 MySQL 트리거를 사용하여 데이터를 자동으로 보관하는 방법을 소개합니다. 1. MySQL 트리거란 무엇입니까? MySQL 트리거는 특별한 종류의 메모리입니다.

MySQL 트리거에서 매개변수를 사용하는 방법 MySQL 트리거에서 매개변수를 사용하는 방법 Mar 16, 2024 am 09:27 AM

MySQL 트리거는 데이터베이스 관리 시스템에서 특정 테이블의 작업을 모니터링하고 미리 정의된 조건에 따라 해당 작업을 수행하는 데 사용되는 특수 프로그램입니다. MySQL 트리거를 생성할 때 매개변수를 사용하여 데이터와 정보를 유연하게 전달할 수 있으므로 트리거를 더욱 다양하고 적용 가능하게 만들 수 있습니다. MySQL에서 트리거는 특정 테이블의 INSERT, UPDATE 및 DELETE 작업 전후에 해당 논리를 트리거하고 실행할 수 있습니다. 매개변수를 사용하면 트리거를 더욱 유연하게 만들 수 있으며 필요에 따라 전달할 수 있습니다.

See all articles