--触发器是一类特殊的监控增删改操作,并产生相应的增删改的操作
--1,监视谁 2,监视动作 3,监视时间(之前或之后) 4,触发的事件
--触发器的简单语法
create trigger 触发器名字  after/before(触发时间)
insert/delete/update(监视事件) on 表名 (监视地址)
for each row begin sql语句; end;
--因为一条sql语句只能有一个边界符,所以上面语句会发生错误,用delimiter $
--将边界符改为$ 这样就不会发生冲突
--同一个表在同一时间同意动作不能有不同的触发器
--查看已有的触发器 show triggers;
--删除指定的触发器 drop trigger 触发器名字;
--建表语句
create table goods(
goods_id int not null,
goods_name varchar(30) not null default '',
goods_num int
)engine myisam charset utf8; --插入数据
insert into goods values (1,'cat',32),(2,'dog',42),(3,'rab',43); --创建订单表
create table ord(
id int not null,
goods_id int not null,
num int not null default 0
)engine myisam charset utf8;
--更改边界,最后不需要分号;
delimiter $
--创建触发器,当ord表插入一条数据(1,1,1)时 商品cat数量减1
create trigger trig1
after
insert
on ord
for each row
begin
update goods set goods_num=goods_num-1 where goods_id=1;
end$ --然后插入一条数据
insert into ord values (1,1,1)$
--goods表确实减少了1,但是这个触发器不具有通用性,
--不管买几个商品和买多少商品,总是cat商品减1
drop trigger trig1$ --旧的一行数据对象old,新的一条数据对象new
create trigger trig2
after
insert
on ord
for each row
begin
update goods set goods_num=goods_num-new.num where goods_id=new.goods_id;
end$ --这个触发器具有通用性 --监控delete语句,当删除订单时,需要再把商品加回来
create trigger trig3
after
delete
on ord
for each row
begin
update goods set goods_num=goods_num+old.num where goods_id=old.goods_id;
end$ --监控update语句,当更新表时,产生相应的操作,在不修改商品类型的情况
create trigger trig4
after
update
on ord
for each row
begin
update goods set goods_num=goods_num+old.num-new.num where goods_id=new.goods_id;
end$ --在这种情况下,会出现爆仓的情况,因为更新的数据可能超过商品的库存量
drop trigger trig4$
create trigger trig4
before
update
on ord
for each row
begin
declare gnum int;
select goods_num into gnum from goods where goods_id=new.goods_id;
if (new.num-old.num)>gnum then
set new.num=gnum+old.num;
end if;
update goods set goods_num=goods_num+old.num-new.num where goods_id=new.goods_id;
end$ --insert也会出现这种情况,也要更改一下
drop trigger trig2$
create trigger trig2
before
insert
on ord
for each row
begin
declare gnum int ;
select goods_num into gnum from goods where goods_id=new.goods_id;
if new.num>gnum then
set new.num=gnum;
end if;
update goods set goods_num=goods_num-new.num where goods_id=new.goods_id;
end$

MySQL数据库中的触发器的更多相关文章

  1. Oracle数据库中实现mysql数据库中auto-increment功能

    在Mysql数据库中,想要实现一条数据的自增一功能(即插入此数据时填写null即可,系统自动+1),可直接在所在列使用语句auto-increment. id int primary key auto ...

  2. MySQL数据库中delimiter的作用概述

    以下的文章主要是向大家描述的是MySQL数据库中delimiter的作用是什么?我们一般都认为这个命令和存储过程关系不大,到底是不是这样的呢?以下的文章将会给你相关的知识,望你会有所收获. 其实就是告 ...

  3. PHP往mysql数据库中写入中文失败

    该类问题解决办法就是 在建立数据库连接之后,将该连接的编码方式改为中文. 代码如下: $linkID=@mysql_connect("localhost","root&q ...

  4. MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述

    MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述: 1.MySQL有多种存储引擎: MyISAM.InnoDB.MERGE.MEMORY(HEAP).BDB(Berk ...

  5. 从Mysql数据库中导入导出表结构

    1.从Mysql数据库中导入sql表 很简单,只需要一个命令即可搞定:[root@localhost ~]# mysql -uroot -piweb_xxx_mysql iweb < modif ...

  6. 从SQLSERVER/MYSQL数据库中随机取一条或者N条记录

    从SQLSERVER/MYSQL数据库中随机取一条或者N条记录 很多人都知道使用rand()函数但是怎麽使用可能不是每个人都知道 建立测试表 USE [sss] GO ,NAME ) DEFAULT ...

  7. 在mysql数据库中制作千万级测试表

    在mysql数据库中制作千万级测试表 前言: 最近准备深入的学一下mysql,包括各种引擎的特性.性能优化.分表分库等.为了方便测试性能.分表等工作,就需要先建立一张比较大的数据表.我这里准备先建一张 ...

  8. 查看MYSQL数据库中所有用户及拥有权限

    查看MYSQL数据库中所有用户 mysql> SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM m ...

  9. 【转】mysql数据库中实现内连接、左连接、右连接

    [转]mysql数据库中实现内连接.左连接.右连接 内连接:把两个表中数据对应的数据查出来 外连接:以某个表为基础把对应数据查出来 首先创建数据库中的表,数据库代码如下: /* Navicat MyS ...

随机推荐

  1. 解决安装SQL Server2008失败的问题

    安装SQL Server2008时遇到"2008安装错误  必须重新启动计算机才能安装 SQL Server". 解决办法:HKEY_LOCAL_MACHINE\SYSTEM\Cu ...

  2. 在Oracle数据库启动时提示没有权限 ora-01031:insufficient privileges

    环境:Linux 操作语句: [oracle@ora11r2 ~]$ sqlplus /nolog SQL*Plus: Release 11.1.0.6.0 - Production on Thu J ...

  3. Cocos2d-x——支持多触点

    1:在AppController的didFinishLaunchingWithOptions中,加入 [__glView setMultipleTouchEnabled:YES]; 2:在CCLaye ...

  4. xxx-servlet.xml vs applicationContext.xml

    Spring lets you define multiple contexts in a parent-child hierarchy. The applicationContext.xml def ...

  5. WCF与WebService之间的异同

    下面我们来详细讨论一下二者的区别.Web Service和WCF的到底有什么区别. 1,Web Service:严格来说是行业标准,也就是Web Service 规范,也称作WS-*规范,既不是框架, ...

  6. Java网页数据采集器[续篇-远程操作]【转载】

    本期概述 上期我们学习了html页面采集后的数据查询, 但这仅仅是在本地查询数据库,如果我们想通过远程操作来进行数据的采集,存储和查询,那又该怎么做呢? 今天我们一起来学习下:如何通过本地客户端远程访 ...

  7. delphi 如何知道 Treeview,Listview 当前最上面显示的节点

    如何知道 Treeview,的节点是根节点       procedure TForm1.TreeView1ContextPopup(Sender: TObject; MousePos: TPoint ...

  8. STL中heap算法(堆算法)

     ①push_heap算法 以下是push_heap算法的实现细节.该函数接收两个迭代器,用来表现一个heap底部容器(vector)的头尾,而且新元素已经插入究竟部的最尾端. template ...

  9. 使用sql生成UUID

    在SQLServer中使用该sql语句可以生成GUID:select cast(NEWID() as varchar(36)) as uuid 通过一下语句将GUID中的'-'字符去掉: select ...

  10. JAVA(2)——JDBC

    刚接触JDBC的时候,有时候就在想,为什么java要用JDBC,而不是直接使用之前在VB中就学习过的ODBC,由于ODBC是在JDBC之前出现,所以ODBC肯定由于无法完毕某些操作或者不能非常顺利的完 ...