--触发器是一类特殊的监控增删改操作,并产生相应的增删改的操作
--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. FPGA高级设计——时序分析和收敛(转)

    何谓静态时序分析(Static Timing Analysis,简称STA)? 它可以简单的定义为:设计者提出一些特定的时序要求(或者说是添加特定的时序约束),套用特定的时序模型,针对特定的电路进行分 ...

  2. 代码静态分析工具——splint的学习与使用

    引言 最近在项目中使用了静态程序分析工具PC-Lint,体会到它在项目实施中带给开发人员的方便.PC-Lint是一款针对C/C++语言.windows平台的静态分析工具,FlexeLint是针对其他平 ...

  3. Installation Directory must be on a local hard drive解决办法

    今天带着公司的电脑来杭州这边,同事发来一个Sliksubversion.msi来进行安装,由于系统是win8.1的,直接点击安装不了,真的是醉了,于是乎发挥度娘的力量找到了答案,这里贴出来,供大家来参 ...

  4. PL/pgSQL学习笔记之二

    39.1.1 使用 PL/pgSQL的好处 SQL是 PostgreSQL和其他大多数关系型数据库作为查询语言而使用的语言.它可移植,并容易学习.但是SQL语句必须被数据库服务器逐条地执行. 这意味着 ...

  5. VS2012开发ActiveX插件 尝试1

    今天闲来无聊研究了下 ActiveX插件开发,以前一直以为很牛逼,然后发现还是比较简单的东西.. 首先: 在开始前 准备好 VS12开发工具,cabarc.exe 工具(注:这是 用来 将文件打包成c ...

  6. phpStudy 2014的Apache虚拟主机配置

    安装phpStudy直接百度下载,傻瓜式安装很简单,一直点击下一步即可,中途根据个人爱好设置WWW目录,我的设置在D盘根目录里. 打开虚拟主机配置,打开D:\phpStudy\Apache\conf下 ...

  7. Codeforces Round #313 (Div. 2) A. Currency System in Geraldion 水题

    A. Currency System in Geraldion Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/c ...

  8. zencart技术联盟交流群

    增加500人的免费互助"zencart技术联盟交流群"!名额不多,先到先得! zencart技术联盟俱乐部(1群) ( 已满) zencart技术联盟俱乐部(2群) 群号:1990 ...

  9. 【剑指offer】八皇后问题

    转载请注明出处:http://blog.csdn.net/ns_code/article/details/26614999 剑指offer上解决八皇后问题,没实用传统的递归或非递归回溯法,而是用了非常 ...

  10. AttributeBehavior

    当事件触发的时候... 会循环所有behavior的events  为ower添加事件.....AttributeBehavior  为事件添加如下方法 public function evaluat ...