关于触发器的理解:

进行数据库应用软件的开发时,有时我们碰到表的某些数据的改变时,希望同时

引起其他相关数据改变的需求,利用触发器就能满足这样的需求。

触发器能在表中的某些特定数据变化时自动完成某些查询,运用触发器不仅仅可以

简化程序,而且可以增加程序的灵活性

触发器是一类特殊的事务:

可以监视某种数据的操作(insert/update/delete)

并触发相关的操作(insert/update/delete)

需求:

商品表:goods

订单表:ord

当下一个订单时,对应的商品要相应减少(买几个商品就少几个库存)

分析:

监视谁:ord

监视动作:insert

触犯时间:after

触发时间:update

mysql> create table goods(
-> gid int,
-> name varchar(20),
-> num smallint-> )engine myisam charset utf8;
Query OK, 0 rows affected (0.07 sec) mysql> create table ord(
-> ord int,
-> gid int,
-> much smallint
-> )engine myisam charset utf8;
Query OK, 0 rows affected (0.07 sec)

mysql> insert into goods
-> values
-> (1, 'cat', 14),
-> (2, 'dog', 65),
-> (3, 'horse', 21);
Query OK, 3 rows affected (0.00 sec)
Records: 3 Duplicates: 0 Warnings: 0

当我买了2只猫后, 如果没学过触发器,应该把num的值减2;

而利用触发器,则会使步骤变得智能

mysql> delimiter $  # ‘$’分割符是为了与‘;’做出区别

mysql> create trigger t1  #创建一个触发器
-> after    # 在insert后触发
-> insert   # 触发条件
-> on ord   # 在哪个表建立触发条件
-> for each row   
-> begin    # 开始
-> update goods set num = num - 2 where gid = 1;   # 触发后改变的
-> end$     # 结束
Query OK, 0 rows affected (0.13 sec)

在这个例子中,在每在ord中添加一条记录后,goods表的cat行num都会减2;但无论你在ord表内添加任何信息,goods表的cat行num只会减2

  优化只能减cat的num-2的问题

触发器引用变量

我们下ord表中,插入的一行叫做new,删除一行叫做old 

如果直接添加会报如下的错误,因为在同一张表中还不支持建立相同触发条件的多个触发器

删除trigger

建立更“智能”的trigger

当建立好t2时,我们来测试一下

建立一个t3,实现退货系统(不会t2冲突吗)

修改订单数据

当要购买的数量大于库存数时,就会出现问题

说明必须在实现该条语句之前,就把数据改为 new.much = 最大的储存量;

MySql cmd下的学习笔记 —— 有关修饰器的知识(trigger)的更多相关文章

  1. MySql cmd下的学习笔记 —— 有关select的操作(in, and, where, like等等)

    为方便本节学习, 请先自行建立本表: 建一个商品表: create table goods ( -> goods_id mediumint(8) unsigned not null auto_i ...

  2. MySql cmd下的学习笔记 —— 引擎和事务(engine,transaction)

    engine 引擎就是MySQL存储数据的不同方式 myisam 插入速度快 支持全文索引 innoDB 插入速度慢 支持事务安全 假设两人同时购买火车票,两人同时看到只有一张火车票,几乎同时下单 或 ...

  3. MySql cmd下的学习笔记 —— 有关视图的操作(algorithm)

    建立一张简单的查询视图,不用临时表,只用条件合并 在简单的查询中,建立临时表的开销比较大 这是可以指定algorithm选项为merge 在v2的视图中,并没有建立临时表 但在下列情况下,必须建立临时 ...

  4. MySql cmd下的学习笔记 —— 有关子查询的操作(where型,from型,exists型子查询)

    先找到goods表 查询goods_id最大的商品 where型的子查询 查询goods_id最大的商品(不能用排序) 把两步写成一步,就是子查询 from型子查询 查找出每种cat_id下goods ...

  5. MySql cmd下的学习笔记 —— 有关多表查询的操作(多表查询练习题及union操作)

    先建立一张 m 表 mysql> create table m ( -> mid int, -> hid int, -> gid int, ), -> matime da ...

  6. MySql cmd下的学习笔记 —— 有关分组的操作(group by)

    (一) 把建立的goods表找到 (二) 当cat_id = 3时,计算所有商品的库存量之和 计算每个cat_id下的库存量(group by) 需要用到分组,把每个红框内的计算在一起 筛选出本店价比 ...

  7. MySql cmd下的学习笔记 —— 有关select的操作(max, min等常见函数)

    先把之前建的goods表找到 找到最贵的本店价(max) 找到最便宜的本店价(min) 查出一共还有多少商品(count) 查看商品价的平均价(avg) 查看本店有多少种商品 当count(*)时 输 ...

  8. MySql cmd下的学习笔记 —— 有关建立表的操作(有关于数据类型)

    (01)建表的过程实际上是 声明字段 的过程 一. 列类型(字段): 存储同样的数据时,不同的列类型,所占据的空间和效率是不一样的,这就是建表时要考虑的意义. 二.MySQL三大列类型     数值型 ...

  9. MySql cmd下的学习笔记 —— 有关表的操作(对表中数据的增,删,改,查)

    (知识回顾) 连接数据库 mysql -uroot -p111 先建立一个新库 create database test1; use test1; 由于今天的主要内容是表的操作,建立表的详细过程不是本 ...

随机推荐

  1. 第一个java程序的编译

    import java.io.*; public class EmployeeTest{ public static void main(String args[]){ /* 使用构造器创建两个对象 ...

  2. idea 设置console 无1024限制,复制到Excel分隔符\t

    在安装目录/bin中找到idea.properties文件, 更改idea.cycle.buffer.size项值为disabled,保存,重启idea Excel分隔符\t; 数字自动加逗号的情况, ...

  3. tuple数组、文件操作

    halcon自带案例的学习. Tuple1 := [,,,,] //数组 Number := |Tuple1| //元素个数 SingleElement := Tuple1[] Part := Tup ...

  4. windows怎样查看被程序占用的端口

    1. netstat -ano  显示所有端口与任务管理器中的pid对应,通过pid打开任务管理器查询占用进程 附录:在命令行中输入netstat /? 可以查看netstat的相关信息.C:\Doc ...

  5. (链表 双指针) leetcode 19. Remove Nth Node From End of List

    Given a linked list, remove the n-th node from the end of list and return its head. Example: Given l ...

  6. data_type

    import logging logger = logging.getLogger("simple_example") logger.setLevel(logging.DEBUG) ...

  7. 降维方法PCA与SVD的联系与区别

    在遇到维度灾难的时候,作为数据处理者们最先想到的降维方法一定是SVD(奇异值分解)和PCA(主成分分析). 两者的原理在各种算法和机器学习的书籍中都有介绍,两者之间也有着某种千丝万缕的联系.本文在简单 ...

  8. HTTP常用头部信息

    下面用例子的形式来记录下常用的一些Http头部信息 Request Header: GET /sample.Jsp HTTP/1.1  //请求行 Host: www.uuid.online/  // ...

  9. OpenDayLight——HelloWorld

    OpenDayLight——HelloWorld 既然学习OpenDayLight编程这个鬼,就得像学语言一样来一个HelloWorld来试试水,经过几天的折腾,总算成功输出HelloWorld了,这 ...

  10. PHP索引数组+unset使用不当导致的问题

    转自先知社区 https://xz.aliyun.com/t/2443 0x00前言 通常网站后台可以配置允许上传附件的文件类型,一般登录后台,添加php类型即可上传php文件getshell.但是, ...