当前位置: 首页 > news >正文

福州做网站建设服务商最近一周新闻大事摘抄

福州做网站建设服务商,最近一周新闻大事摘抄,网络规划设计师历年试题分析与解答,wordpress获取日期的年月日触发器 简介 触发器用于直接在某种操作后(数据的增删改查等),通过事件执行设置触发器时的 sql 语句,具有原子性。 可通过 sql 语句直接编写,关键词:CREATE TRIGGER 触发器名称。 例如:在表 st…

触发器

简介

触发器用于直接在某种操作后(数据的增删改查等),通过事件执行设置触发器时的 sql 语句,具有原子性。
可通过 sql 语句直接编写,关键词:CREATE TRIGGER 触发器名称。
例如:在表 student 上,创建触发器 test (CREATE TRIGGER test),在新增一行数据之后(AFTER INSERT),根据 student 的 classId ,在表 class 中,找到 id 所在行,设置 number + 1。

DELIMITER $$
$$
CREATE TRIGGER `test`
AFTER INSERT
ON student FOR EACH ROW
BEGIN UPDATE class set number = number + 1 WHERE id = NEW.classId;
END
$$
DELIMITER ;

后面方便,直接使用 Dbeaver 创建触发器

NEW和OLD

这两个关键词是 mysql 设定的两张临时表名

触发器NEWOLD
insert表示将要(BEFORE)或者已经(ALTER)插入的数据×
delete×表示将要(BEFORE)或者已经(ALTER)删除的数据
update表示将更新后的数据表示更新前的数据

例子

新建表 学生student 、班级class
student表
class表

insert

  • AFTER INSERT,插入之后触发
    如:新增一名学生,对应班级number + 1
    1、创建触发器:
    创建触发器1
    创建触发器2
    触发器内容
    sql 语句写于BEGIN 和 END 之间。因为是在student 表上的插入后触发ALTER INSERT ,我们要更新 class 表,设置number 列的值+1,条件是student 插入数据后,新的student临时表(NEW)的classId,等于= class表的 id 。

执行
2、执行后:
执行后
3、测试:
在表student 新增一个学生,学生的classId,指定是class 表的火箭班的id=3
插入数据
这时候查看class 表,是否火箭班对应的number变为了1
查看结果

  • BEFORE INSERT,插入之前触发
    如:新增一名学生前,先查询该学生名称如果是“小六”,则提示“请输入正确的姓名!”
    从MySQL 5.5开始,您可以使用SIGNAL语法抛出异常:
signal sqlstate '45000' set message_text = 'My Error Message';

状态45000是表示"未处理的用户定义的异常"的通用状态

1、创建触发器:
在这里插入图片描述
2、测试:
添加名为“小六”的学生失败
在这里插入图片描述
正常添加一个学生:
在这里插入图片描述
到这里,目前存在了两个触发器在student表中
在这里插入图片描述
mysql中,执行顺序:BEFORE触发器->增删该操作->ALTER触发器
所以在经过addStudent BEFORE INSERT 触发器判断后,将要插入student 的数据,也会经过addClassNumber 触发器,
在class 的number + 1
在这里插入图片描述

delete

  • AFTER DELETE
    如:删除一名学生之后,class 表对应的 班级number - 1
    1、创建触发器
    在这里插入图片描述
    2、测试:
    删掉普通班的王五和赵六
    在这里插入图片描述
    现在普通班只剩下1人张三
    在这里插入图片描述

  • BEFORE DELETE
    如:删除相应的班级之前,查询该班是否还有学生,如果有,就提示无法删除
    1、在class 上创建触发器
    在这里插入图片描述
    在这里插入图片描述
    2、测试:
    删除普通班
    在这里插入图片描述
    删除重点班:
    在这里插入图片描述

update

关于update的就不多说了,可以在更新学生student 表的classId后,也在class 表的对应班级number + 1基本的逻辑都类似,更多的是根据业务来选择及编写触发器。
在这里插入图片描述
测试:
在这里插入图片描述
在这里插入图片描述
写到这里,暂时完成了触发器的简单使用。后续有需要在继续更新上来。

可以看看我的个人博客:
网站:https://www.fuzm.wang / https://liwangc.gitee.io
—————————————————————————
作为初学者,很多知识都没有掌握,见谅,如有错误请指出,以期进步,感谢!。后续有新的学习,继续补充上来。

http://www.hkea.cn/news/482930/

相关文章:

  • 2018什么做网站百度网盘网页版入口
  • 深圳福田大型商城网站建设石家庄最新疫情最新消息
  • 网站版面结构chatgpt 网站
  • 网站后期推广是谁来做广州百度推广开户
  • 不上此网站枉做男人免费制作网站平台
  • 防红短链接生成佛山抖音seo
  • 网站建设php带数据库模板站长工具四叶草
  • 做网站客户拖着不验收店铺推广渠道有哪些方式
  • 站群系统哪个好用怎样进行seo推广
  • 淄博网站建设方案网络推广是做什么的
  • 网站建设销售工作职责seo平台怎么样
  • 免费的网站给一个百度seo优化服务项目
  • 现代广告创意设计郑州百度网站优化排名
  • 兰州网站建设哪家专业谷歌seo网站推广
  • 崇信门户网站留言回复上优化seo
  • 网站建设费用有哪些站长工具搜索
  • 云主机能干什么独立站seo怎么做
  • 苏州专业网站建设设计公司免费发布推广信息的b2b
  • 空间 两个网站网络推广培训班
  • 零基础学做网站推广公司简介
  • 公司做网站最好引擎搜索器
  • 济南手工网站建设北京百度seo服务
  • 网站建设原创百度seo官网
  • 徐州企业网站建设衡阳seo服务
  • 网站自然排名优化seo专员是什么职业
  • 视频网站制作广告代理公司
  • wordpress主题域名授权密钥生成镇海seo关键词优化费用
  • 北京东直门+网站建设汕头seo外包平台
  • 长沙 做网站企业网络组网设计
  • 北京哪家做网站优化产品seo基础优化