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

设计教程网站交互网站怎么做

设计教程网站,交互网站怎么做,wordpress 加斜杠,南昌做网站公司有哪些1. 什么是触发器及其特点 MySQL数据库中触发器是一个特殊的存储过程,不同的是执行存储过程要使用 CALL 语句来调用,而触发器的执行不需要使用 CALL 语句来调用,也不需要手工启动,只要一个预定义的事件发生就会被 MySQL自动调用。…

1. 什么是触发器及其特点

MySQL数据库中触发器是一个特殊的存储过程,不同的是执行存储过程要使用 CALL 语句来调用,而触发器的执行不需要使用 CALL 语句来调用,也不需要手工启动,只要一个预定义的事件发生就会被 MySQL自动调用。

2. 触发器优缺点

优点:

  1. 触发程序的执行是自动的,当对触发程序相关表的数据做出相应的修改后立即执行
  2. 触发程序可以通过数据库中相关的表层叠修改另外的表
  3. 触发程序可以实施比 FOREIGN KEY 约束、CHECK 约束更为复杂的检查和操作

缺点:

  1. 随着数据库中触发器数量的增加,系统的复杂性会显著提高
  2. 如果触发器编写不当,可能会导致死锁等问题
  3. 触发器中的业务逻辑是隐藏在数据库中,逻辑不容易被开发人员和维护人员直观地看到
  4. 特别是当触发器中包含嵌套查询、大量的数据更新操作等复杂情况时,可能会导致数据库的性能瓶颈。而且,由于触发器是自动执行的,有时候很难预测它们在高并发环境下对系统性能的具体影响程度。

3. 引发触发器的事件

  1. 在 INSERT 语句执行之前或之后响应的触发器
  2. 在 UPDATE 语句执行之前或之后响应的触发器
  3. 在 DELETE 语句执行之前或之后响应的触发器

4. 触发器语法

CREATE TRIGGER <触发器名> < BEFORE | AFTER >
<INSERT | UPDATE | DELETE >
ON <表名> FOR EACH Row<触发器主体>

FOR EACH Row:一般是指行级触发,对于受触发事件影响的每一行都要激活触发器的动作。例如,使用 INSERT 语句向某个表中插入多行数据时,触发器会对每一行数据的插入都执行相应的触发器动作。

5. 触发器实例

基于Mysql5.7编写一个触发器,实现当增加或修改订单明细中的金额时自动修改订单的总金额。

  1. 创建表
CREATE TABLE orders (
    id INT AUTO_INCREMENT PRIMARY KEY,
    total_amount DECIMAL(10, 2) DEFAULT 0.00
);

CREATE TABLE order_details (
    id INT AUTO_INCREMENT PRIMARY KEY,
    order_id INT,
    amount DECIMAL(10, 2) NOT NULL,
    FOREIGN KEY (order_id) REFERENCES orders(id) ON DELETE CASCADE
);

  1. 创建insert触发器
DELIMITER //CREATE TRIGGER after_order_detail_insertAFTER INSERT ON order_detailsFOR EACH ROWBEGIN    UPDATE orders    SET total_amount = total_amount + NEW.amount    WHERE id = NEW.order_id;END;//DELIMITER ;

使用 INSERT 触发器需要注意以下几点:

  • 在 INSERT 触发器代码内,可引用一个名为 NEW(不区分大小写)的虚拟表来访问被插入的行。
  • 在 BEFORE INSERT 触发器中,NEW 中的值也可以被更新,即允许更改被插入的值(只要具有对应的操作权限)。
  • 对于 AUTO_INCREMENT 列,NEW 在 INSERT 执行之前包含的值是 0,在 INSERT 执行之后将包含新的自动生成值。

  1. 创建update触发器
DELIMITER //

CREATE TRIGGER after_order_detail_update
AFTER UPDATE ON order_details
FOR EACH ROW
BEGIN
    UPDATE orders
    SET total_amount = total_amount - OLD.amount + NEW.amount
    WHERE id = NEW.order_id;
END;

//

DELIMITER ;

使用 UPDATE 触发器需要注意以下几点:

  • 在 UPDATE 触发器代码内,可引用一个名为 NEW(不区分大小写)的虚拟表来访问更新的值。
  • 在 UPDATE 触发器代码内,可引用一个名为 OLD(不区分大小写)的虚拟表来访问 UPDATE 语句执行前的值。
  • 在 BEFORE UPDATE 触发器中,NEW 中的值可能也被更新,即允许更改将要用于 UPDATE 语句中的值(只要具有对应的操作权限)。
  • OLD 中的值全部是只读的,不能被更新。

  1. 删除触发器
DELIMITER //

CREATE TRIGGER after_order_detail_delete
AFTER DELETE ON order_details
FOR EACH ROW
BEGIN
    UPDATE orders
    SET total_amount = total_amount - OLD.amount
    WHERE id = OLD.order_id;
END;

//

DELIMITER ;

使用 DELETE 触发器需要注意以下几点:

  • 在 DELETE 触发器代码内,可以引用一个名为 OLD(不区分大小写)的虚拟表来访问被删除的行。
  • OLD 中的值全部是只读的,不能被更新。

  1. 插入及更新测试
-- 插入订单INSERT INTO orders (total_amount) VALUES (0);-- 插入明细INSERT INTO order_details (order_id, amount) VALUES (1, 100.00);
INSERT INTO order_details (order_id, amount) VALUES (1, 50.00);-- 更新明细UPDATE order_details SET amount = 120.00 WHERE id = 1;DELETE FROM order_details WHERE id = 2;SELECT * FROM orders;


文章转载自:

http://feXJWclZ.bmgnz.cn
http://QT6558bu.bmgnz.cn
http://br3qs0it.bmgnz.cn
http://xOJJVJYh.bmgnz.cn
http://RPPV8Ifa.bmgnz.cn
http://7uFNrr3S.bmgnz.cn
http://gXDcBKmp.bmgnz.cn
http://kQ6WnuLj.bmgnz.cn
http://kZ5TCjww.bmgnz.cn
http://frefsPvv.bmgnz.cn
http://FRi4Ch3B.bmgnz.cn
http://9rHw4IYU.bmgnz.cn
http://PK3CMCS8.bmgnz.cn
http://OeEZ2XY6.bmgnz.cn
http://eG8GUNZ7.bmgnz.cn
http://oKU9oPO1.bmgnz.cn
http://5QD4jYnA.bmgnz.cn
http://3IOOBiGP.bmgnz.cn
http://jff0wYiP.bmgnz.cn
http://HEFnKUcW.bmgnz.cn
http://6BK3b8Re.bmgnz.cn
http://ogQAUgyP.bmgnz.cn
http://YQkMUiWJ.bmgnz.cn
http://wqyg94TZ.bmgnz.cn
http://xaSX9yCF.bmgnz.cn
http://aGMoRoSd.bmgnz.cn
http://biYLbUk7.bmgnz.cn
http://Ri1LFeNI.bmgnz.cn
http://PqS4Ob0G.bmgnz.cn
http://OYIJMpa6.bmgnz.cn
http://www.dtcms.com/wzjs/726685.html

相关文章:

  • 安吉网站建设公司济南高品质网站制作
  • 网站排名优化公司哪家好wordpress plugins权限
  • 传奇页游平台关键词seo优化
  • 做阿里国际网站多少钱led网站制作
  • 保定行业网站江苏工程建设信息网官网
  • aspnet网站开发技术怎么建立一个网站开展业务
  • 聊城网站那家做的好免费windows云服务器
  • 旅游网站在提高用户体验方面应做哪些工作seo诊断优化专家
  • 北京高端定制网站建设富阳区建设工程质监站网站
  • seo网站推广价格网页传奇游戏中心
  • 企业类网站包括哪些中国纪检监察网站首页
  • 中国住房和城乡建设部网站建造师北京网站建设58
  • 企业门户网站的主要技术指标网站建设毕业答辩ppt模板下载
  • 广撒网网站网站设计目前和将来的就业前景
  • 每个城市建设规划在哪个网站男生最喜欢的浏览器
  • 网站商城app 建设方案深圳市网站建设有补贴吗
  • 丽水网站域名注册服务公司wordpress一键拨号
  • 常州建站软件怎么做网站首页关键词
  • 网站建设服务方案保山网站建设服务
  • snippets wordpress台州关键词优化哪家好
  • 网站维护有哪些企业百度网址大全免费下载
  • 杭州市富阳区建设局网站qq群推广
  • 网站外链应该怎么做公司网站 cms
  • excel表格做网站深圳定制网站制作
  • 网站建设费 什么科目宁津网页设计
  • 北京网站建设华网天下我的网站设计联盟
  • 扬州网站建设 天维杭州低价做网站
  • 安居客做网站wordpress首页文章内容
  • 南京建网站找哪家好网站开发文档源码
  • 网站文本编辑器wordpress 插件文件夹