关于触发器的理解:

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

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

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

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

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

可以监视某种数据的操作(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. JVM与GC

    1.JVM的内存分配参考文章: https://www.cnblogs.com/wangjzh/p/5258254.html 2. java之GC https://www.cnblogs.com/hn ...

  2. IE缓存查看的方法

    选择设置中的Internet选项中, 然后点击查看文件: 最终缓存目录:

  3. 机器学习算法 Python&R 速查表

    sklearn实战-乳腺癌细胞数据挖掘( 博主亲自录制) https://study.163.com/course/introduction.htm?courseId=1005269003&u ...

  4. python操作execl学习笔记(一)

    本节只记录关于execl的读操作: execl 内容及格式 python3 #!/usr/bin/env python #-*- coding:utf-8 -*- import xlrd import ...

  5. 面向对象【day08】:异常处理(六)

    本节内容 1.概述 2.异常梳理 3.异常梳理流程图 4.异常大全 5.自定义异常 一.概述 异常处理是当程序出错了,但是我们又不想让用户看到这个错误,而且我在写程序的时候已经预料到了它可以出现这样的 ...

  6. java io系列20之 PipedReader和PipedWriter

    本章,我们学习PipedReader和PipedWriter.它们和“PipedInputStream和PipedOutputStream”一样,都可以用于管道通信. PipedWriter 是字符管 ...

  7. linux备份用户权限

    1:切换root用户,进入home目录,执行以下命令: [root@localhost home]# ll /home/wangfajun 2: home目录下执行以下命令进行wangfajun用户的 ...

  8. JAVA入门教程 - idea 新建maven spring MVC项目

    用的是Idea2017版本.其他大同小异 1.新建项目 2.勾选Create from archetype 选中maven-archetype-webapp 3.输入项目名字. 4.下一步 5.点Fi ...

  9. Part-Four

    1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12.

  10. Consul 域名服务

    =============================Web请求的全过程(包含DNS) =============================完整过程参考 https://blog.csdn. ...