What is a trigger:
Trigger (trigger) is a method provided by SQL server to programmers and data analysts to ensure data integrity. It is a special storage related to table events. Process, its execution is not called by a program or started manually, but is triggered by events. For example, when a table is operated (insert, delete, update), its execution will be activated. Triggers are often used to enforce data integrity constraints and business rules. Triggers can be found in the DBA_TRIGGERS and USER_TRIGGERS data dictionaries. A SQL3 trigger is a statement that can be automatically executed by the system to modify the database.
Trigger syntax:
CREATE TRIGGER A table can only create one trigger Trigger (trigger): monitor a certain situation and trigger a certain operation. Four elements of trigger creation syntax: 1. Monitoring location (table) 2. Monitoring event (insert/update/delete) 3. Triggering time (after/before) 4. Triggering event (insert/update/delete) ) Syntax: sql statement; end; Note: Each color corresponds to the four elements above. First we create two tables: If we don’t use triggers: Suppose we sell 3 items 1 now, we need to do two things 1. Insert a record into the order table 2. Update the remaining quantity of product 1 in the product table Now, let’s create a trigger: Required First execute the statement: delimiter $ (meaning to tell the mysql statement to end with $) At this time we only need to execute: will find that the quantity of product 1 becomes 7 , indicating that when we insert an order, the trigger automatically performs the update operation for us. But now there is a problem, because the num and id in our trigger are hard-coded, so no matter which product we buy, the quantity of product 1 will be updated in the end. For example: we insert another record into the order table: insert into o(gid,much) values(2,3). After execution, we will find that the quantity of product 1 has changed to 4, but the quantity of product 2 has not changed. This is obviously not the case. the results we want. We need to change the trigger we created earlier. How do we reference the value of the row in the trigger, that is to say, we need to get the gid or much value in our newly inserted order record. For insert, the newly inserted row is represented by new, and the value of each column in the row is represented by new.column name. So now we can change our trigger like this The second trigger is created, let’s delete the first trigger first drop trigger tg1$ Let’s test it again and insert an order record: insert into o(gid,much) values(2,3)$ After execution, it is found that the quantity of product 2 has changed to 7. That's right now. There are still two situations: 1. When a user cancels an order, we delete an order directly. Do we need to add back the corresponding quantity of goods? ? 2. When the user modifies the quantity of an order, how do we write the trigger modification? Let’s analyze the first situation first: Monitoring location: o table Monitoring event: delete Trigger time: after Trigger event: update For delete: There was originally a row, but it was deleted later. To reference the deleted row, use old to represent it. The old. column name can refer to the value of the deleted row. Then our trigger should be written like this: Created. Execute delete from o where oid = 2$ and you will find that the quantity of product 2 has changed to 10 again. Second case: Monitoring location: o table Monitoring event: update Trigger time: after Trigger event :update For update: The modified row, the data before modification, is represented by old, and the old. column name refers to the value in the row before modification; After modification The data is represented by new, and the new. column name refers to the value in the row after it is modified. Then our trigger should be written like this: First restore the old quantity and then subtract the new quantity to get the modified quantity. Let’s test it: first clear the data in the product table and order table for easy testing. Suppose we insert three products into the product table, the quantity is 10, Buy 3 products 1: insert into o(gid,much) values(1,3)$ At this time, the quantity of product 1 becomes 7; We then modify the inserted order record: update o set much = 5 where oid = 1$ We change it to buy 5 Product 1. If you query the product table at this time, you will find that the number of Product 1 is only 5, indicating that our trigger has worked. The above is all about the triggers in this article, I hope it can help you. Related recommendations: Questions about MySQL triggers Detailed explanation of indexes and triggers in MySQL Detailed explanation of operation examples of triggers in Mysql
{ BEFORE | AFTER } --Triggers have execution time settings: they can be set before or after the event occurs.
{ INSERT | UPDATE | DELETE } --You can also set the triggered events: they can be triggered during the execution of insert, update or delete.
ON --The trigger belongs to a certain table: when an insert, update, or delete operation is performed on this table, the trigger is activated. We cannot give the trigger to the same table. An event schedules two triggers.
FOR EACH ROW --Trigger execution interval: The FOR EACH ROW clause notifies the trigger to perform an action every other row, rather than once for the entire table. create trigger triggerName
after/before insert/update/delete on 表名
for each row #这句话在mysql是固定的
begin
#商品表
create table g
(
id int primary key auto_increment,
name varchar(20),
num int
);
#订单表
create table o
(
oid int primary key auto_increment,
gid int,
much int
);
insert into g(name,num) values('商品1',10),('商品2',10),('商品3',10);
insert into o(gid,much) values(1,3);
update g set num=num-3 where id=1;
create trigger tg1
after insert on o
for each row
begin
update g set num=num-3 where id=1;
end$
insert into o(gid,much) values(1,3)$
create trigger tg2
after insert on o
for each row
begin
update g set num=num-new.much where id=new.gid;(注意此处和第一个触发器的不同)
end$
create trigger tg3
after delete on o
for each row
begin
update g set num = num + old.much where id = old.gid;(注意这边的变化)
end$
create trigger tg4
after update on o
for each row
begin
update g set num = num+old.much-new.much where id = old/new.gid;
end$
The above is the detailed content of Detailed explanation of mysql triggers. For more information, please follow other related articles on the PHP Chinese website!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

WebStorm Mac version
Useful JavaScript development tools

Atom editor mac version download
The most popular open source editor

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
