数据库实践LAB大纲 04 触发器
游标
系统为用户开设的一个数据缓冲区 —— 存T-SQL语句从数据库检索出来的结果集
对结果集处理:结果集一条条提取记录,这时要用游标
使用
- 利用基于变量的select into语句,只能处理单条记录
- 使用游标循环处理
- 声明游标: DECLARE cursor_name CURSOR FOR select_statement
- 打开游标 :OPEN cursor_name
- 使用游标 :FETCH cursor_name INTO var_name [, var_name] …
- 关闭游标 :CLOSE cursor_name
顺序
- 游标声明在处理程序之前,在变量和条件之后
- select 语句 不能出现INTO语句
特性
- 允许应用程序对 查询语句 select 返回结果集“某一行”进行操作,rather than一次对整体做同一个操作
- 只读: 不可能新基础表数据
- 不可滚动:按确定顺序获取行,不能以相反顺序获取,不可跳行
- 敏感: 敏感游标指向实际数据(类似指针,引用),不敏感游标使用临时副本(类似传参)
- 前者比后者更快,因为不需要copy临时数据
- 但其他数据做的更改会影响前者的数据。
create procedure qq_cursor_insert()
begindeclare a varchar(15);declare b int;declare cur1 cursor for select qqno, tid from qq;declare exit handler for not found close cur1;open cur1;repeatfetch cur1 into a, b;insert into new_qq(a, b) values(a, b);until 0end repeatl;close cur1;
end;
触发器
定义了一系列操作,这一系列操作称为触发程序,当触发事件发生时,触发程序会自动运行
主要监视以下情况
- insert
- update
- delete
行驶时间可设置为
- before
- after
特点
- 安全性:使users具有操作数据库的某种权利,比如基于时间限制,规定时间外不能修改;比如基于数据限制,不允许分数为负数
- 审计: 跟踪user对数据库的操作
- 复杂的数据完整性规则: 完整性检查和约束,如触发器可回退 任何企图吃进超过自己保证金的期货
- 复杂的非标准的数据库相关完整性规则: cascade 修改 或删除匹配行/设置null或default/拒绝、回退破坏相关完整性的变化
创建
触发程序是与表有关的命名数据库对象,创建后该对象在MySQL中
语法
create trigger trigger_name trigger_time trigger_event
on tbl_name for each row trigger_stmt
- trigger_name: 名字,唯一名称
- trigger_time :触发器被触发的时间 BEFORE(验证新数据是否满足使用的限制) | AFTER(激活触发器的语句执行之后完成几个或更多的改变)
- trigger_event : 激活触发器的语句的类型
- tbl_name:与触发器相关联的表名,不能为TEMPORARY表或VIEW(同一个表不能拥有两个具有相同触发时刻和事件的触发器,可能其他版本会有差异)
- for each row:用来指定对于受触发事件影响的每一行都要激活触发器的动作
- trigger_stmt:是当触发程序激活时执行的语句。 多个语句用 BEGIN END结构
example – 限制某些字段在 60, 150, 230内
delimiter $$
create trigger course_insert_before_trigger before insert
beginif(new.up_limit = 60 || new.up_limit = 150 )then set new.up_limit = new.up_limit;else insert into mytable values(0); -- 注意 mytable并不存在于数据库中--原理是创造一个error终止这次insertend if
end;
delimiter ;
OLD和NEW访问受trigger影响的字段值
- INSERT 只能用 NEW
- DELETE 只能用 OLD
- UPDATE, 可以用OLD引用更新前的值,也可能用 NEW引用更新后的值
- OLD只读,不可改
example – update触发器限制某些字段在 60, 150, 230内
delimiter $$
create trigger course_update_before_trigger before update
on course for each row
beginif(new.up_limit!=60||new.up_limit!=150||new.up_limit!=230) then set new.up_limit=old.up_limit;
end if;
end;
$$
delimiter ;
查看触发器
show triggers
查看当前数据库中所有触发器的信息select *from information_schema.triggers
触发器的定义都存放在information_schema数据库下的triggers表中show create trigger
检查特定触发器定义- 创建触发器后,MySQL自动在数据库目标下创建TRN以及TRG触发器文件,可以自行打开
删除触发器
drop trigger [schema_name.]trigger_name
- schema_name.:可选项 指定数据库
- trigger_name 触发器
- drop trigger要super权限
- 删除一个表的同时,也会自动删除表上的触发器,trigger不可更新覆盖
注意事项
创建
- trigger内部select语句不能返回结果集
- 同一个表不能创建两个相同触发时间、触发事件的触发程序(5.7.2版本之后可以)
- 不可使用事务相关语句
- start transaction
- commit
- rollback
- set autocommit=0
- MySQL触发器针对记录进行操作,当批量更新数据时,引入触发器会导致批量更新操作的性能降低
引擎执行的过程
- MySQL存储引擎 MyISAM中, trigger不能保证原子性
- 更新表的同时,trigger实现另一个表的更新,若trigger程序失败了,不会回滚这次更新前一个表的操作。
- InnoDB引擎支持十五,trigger保持更新操作和trigger操作的原子性 —— 把他们视为同一个transaction
- InnoDB存储引擎实现外键约束关系时,建议使用级联选项维护外键数据 —— 先维护 子表数据,再维护父表
触发器的使用过程
- trigger内部不能使用update(用set代替)
- before处罚程序中:auto_increament字段的new值为0 instead of 实际插入新纪录时自动生成的自增型字段值
例子
- 维护冗余数据 —— 避免数据不一致问题的发生
- 模拟外键级联选项
- 对于InnoDB存储引擎的表而言,由于支持外键约束,在定义外键约束时,通过设置外键的级联选项cascade、set null或者no action(restrict),外键约束关系可以交由InnoDB存储引擎自动维护
- 如果InnoDB存储引擎的表之间存在外键约束关系,但是不存在级联选项或者使用数据库表为MyISAM(该表不支持外键约束关系),则可以使用触发器模拟实现“外键约束”之间的“级联选项
游标
系统为用户开设的一个数据缓冲区 —— 存T-SQL语句从数据库检索出来的结果集
对结果集处理:结果集一条条提取记录,这时要用游标
使用
- 利用基于变量的select into语句,只能处理单条记录
- 使用游标循环处理
- 声明游标: DECLARE cursor_name CURSOR FOR select_statement
- 打开游标 :OPEN cursor_name
- 使用游标 :FETCH cursor_name INTO var_name [, var_name] …
- 关闭游标 :CLOSE cursor_name
顺序
- 游标声明在处理程序之前,在变量和条件之后
- select 语句 不能出现INTO语句
特性
- 允许应用程序对 查询语句 select 返回结果集“某一行”进行操作,rather than一次对整体做同一个操作
- 只读: 不可能新基础表数据
- 不可滚动:按确定顺序获取行,不能以相反顺序获取,不可跳行
- 敏感: 敏感游标指向实际数据(类似指针,引用),不敏感游标使用临时副本(类似传参)
- 前者比后者更快,因为不需要copy临时数据
- 但其他数据做的更改会影响前者的数据。
create procedure qq_cursor_insert()
begindeclare a varchar(15);declare b int;declare cur1 cursor for select qqno, tid from qq;declare exit handler for not found close cur1;open cur1;repeatfetch cur1 into a, b;insert into new_qq(a, b) values(a, b);until 0end repeatl;close cur1;
end;
触发器
定义了一系列操作,这一系列操作称为触发程序,当触发事件发生时,触发程序会自动运行
主要监视以下情况
- insert
- update
- delete
行驶时间可设置为
- before
- after
特点
- 安全性:使users具有操作数据库的某种权利,比如基于时间限制,规定时间外不能修改;比如基于数据限制,不允许分数为负数
- 审计: 跟踪user对数据库的操作
- 复杂的数据完整性规则: 完整性检查和约束,如触发器可回退 任何企图吃进超过自己保证金的期货
- 复杂的非标准的数据库相关完整性规则: cascade 修改 或删除匹配行/设置null或default/拒绝、回退破坏相关完整性的变化
创建
触发程序是与表有关的命名数据库对象,创建后该对象在MySQL中
语法
create trigger trigger_name trigger_time trigger_event
on tbl_name for each row trigger_stmt
- trigger_name: 名字,唯一名称
- trigger_time :触发器被触发的时间 BEFORE(验证新数据是否满足使用的限制) | AFTER(激活触发器的语句执行之后完成几个或更多的改变)
- trigger_event : 激活触发器的语句的类型
- tbl_name:与触发器相关联的表名,不能为TEMPORARY表或VIEW(同一个表不能拥有两个具有相同触发时刻和事件的触发器,可能其他版本会有差异)
- for each row:用来指定对于受触发事件影响的每一行都要激活触发器的动作
- trigger_stmt:是当触发程序激活时执行的语句。 多个语句用 BEGIN END结构
example – 限制某些字段在 60, 150, 230内
delimiter $$
create trigger course_insert_before_trigger before insert
beginif(new.up_limit = 60 || new.up_limit = 150 )then set new.up_limit = new.up_limit;else insert into mytable values(0); -- 注意 mytable并不存在于数据库中--原理是创造一个error终止这次insertend if
end;
delimiter ;
OLD和NEW访问受trigger影响的字段值
- INSERT 只能用 NEW
- DELETE 只能用 OLD
- UPDATE, 可以用OLD引用更新前的值,也可能用 NEW引用更新后的值
- OLD只读,不可改
example – update触发器限制某些字段在 60, 150, 230内
delimiter $$
create trigger course_update_before_trigger before update
on course for each row
beginif(new.up_limit!=60||new.up_limit!=150||new.up_limit!=230) then set new.up_limit=old.up_limit;
end if;
end;
$$
delimiter ;
查看触发器
show triggers
查看当前数据库中所有触发器的信息select *from information_schema.triggers
触发器的定义都存放在information_schema数据库下的triggers表中show create trigger
检查特定触发器定义- 创建触发器后,MySQL自动在数据库目标下创建TRN以及TRG触发器文件,可以自行打开
删除触发器
drop trigger [schema_name.]trigger_name
- schema_name.:可选项 指定数据库
- trigger_name 触发器
- drop trigger要super权限
- 删除一个表的同时,也会自动删除表上的触发器,trigger不可更新覆盖
注意事项
创建
- trigger内部select语句不能返回结果集
- 同一个表不能创建两个相同触发时间、触发事件的触发程序(5.7.2版本之后可以)
- 不可使用事务相关语句
- start transaction
- commit
- rollback
- set autocommit=0
- MySQL触发器针对记录进行操作,当批量更新数据时,引入触发器会导致批量更新操作的性能降低
引擎执行的过程
- MySQL存储引擎 MyISAM中, trigger不能保证原子性
- 更新表的同时,trigger实现另一个表的更新,若trigger程序失败了,不会回滚这次更新前一个表的操作。
- InnoDB引擎支持十五,trigger保持更新操作和trigger操作的原子性 —— 把他们视为同一个transaction
- InnoDB存储引擎实现外键约束关系时,建议使用级联选项维护外键数据 —— 先维护 子表数据,再维护父表
触发器的使用过程
- trigger内部不能使用update(用set代替)
- before处罚程序中:auto_increament字段的new值为0 instead of 实际插入新纪录时自动生成的自增型字段值
例子
- 维护冗余数据 —— 避免数据不一致问题的发生
- 模拟外键级联选项
- 对于InnoDB存储引擎的表而言,由于支持外键约束,在定义外键约束时,通过设置外键的级联选项cascade、set null或者no action(restrict),外键约束关系可以交由InnoDB存储引擎自动维护
- 如果InnoDB存储引擎的表之间存在外键约束关系,但是不存在级联选项或者使用数据库表为MyISAM(该表不支持外键约束关系),则可以使用触发器模拟实现“外键约束”之间的“级联选项
相关文章:
数据库实践LAB大纲 04 触发器
游标 系统为用户开设的一个数据缓冲区 —— 存T-SQL语句从数据库检索出来的结果集 对结果集处理:结果集一条条提取记录,这时要用游标 使用 利用基于变量的select into语句,只能处理单条记录使用游标循环处理 声明游标: DECLA…...
Win10系统电脑开机后总是蓝屏无法使用怎么办?
Win10系统电脑开机后总是蓝屏无法使用怎么办?电脑开机的时候出现了蓝屏问题,这个情况是我们的电脑系统不兼容导致的。遇到这个问题一般是需要去进行系统的重装来解决,安装一个更兼容的系统就可以解决问题了。一起来看看详细的解决方法分享吧。…...
Node——使用nvm切换node版本
1. 下载mvn安装包 https://pan.baidu.com/s/1alfyRvwVWr_TrkN0A9Er5g?pwd1v7c 2. 安装后命令输入mvn -v 验证是否安装成功 3. mvn命令 nvm list available 显示可下载的版本nvm install [node版本号] 显示可下载的版本nvm uninstall [node版本号] 删除已安装的指定版本nvm…...
go语言实现的一个基于go-zero框架的微服务影院票务系统cinema-ticket
一个基于go-zero框架的微服务影院票务系统cinema-ticket 前言 项目基本介绍 项目开源地址:butane123/cinema-ticket: 一个基于go-zero框架的微服务影院票务系统cinema-ticket (github.com) 这是一个微服务影院票务系统,基于go-zero框架实现,…...
ArcGIS API for JavaScript 4.15系列(3)——Dojo中的css样式操作
1、前言 前一篇博客介绍了Dojo中基础的dom操作方法,主要是针对html中的常用标签和属性进行操作。而一个优秀的线上网站自然也离不开css样式的从旁辅助。在实际开发过程中,我们经常会遇到需要动态修改css样式的问题,本文就来介绍一下如何在Do…...
“赶快回家网”首页制作
“赶快回家网”首页制作一、实验名称:二、实验日期:三、实验目的:四、实验内容:五、实验步骤:六、实验结果:七、源程序:八、心得体会:一、实验名称: “赶快回家网”首页…...
JavaWEB-Servlet
目录 Servlet简介Servlet快速入门Servlet配置详解ServletContext 1 Servlet简介 Servlet 运行在服务端的Java小程序,是sun公司提供一套规范(接口),用来处理客户端请求、响应给浏览器的动态资源。但servlet的实质就是java代码&a…...
springboot集成mqtt
引入jar包 <dependency><groupId>org.springframework.integration</groupId><artifactId>spring-integration-mqtt</artifactId> </dependency> <dependency><groupId>com.alibaba</groupId><artifactId>fastjs…...
Lecture3 梯度下降(Gradient Descent)
目录 1 问题背景 2 批量梯度下降 (Batch Gradient Descent) 3 鞍点(Saddle Point) 3 随机梯度下降 (Stochastic Gradient Descent) 4 小批量梯度下降 (Mini-batch Gradient Descent) 1 问题背景 图1 上节课讲述的穷举法求最优权重值在Lecture2中,介绍了使用穷举…...
深入了解DSP
一、时钟和电源 问:DSP的电源设计和时钟设计应该特别注意哪些方面?外接晶振选用有源的好还是无源的好? 答:时钟一般使用晶体,电源可用TI的配套电源。外接晶振用无源的好。 问:TMS320LF2407的A/D转换精度保证…...
Flink反压如何排查
Flink反压利用了网络传输和动态限流。Flink的任务的组成由流和算子组成,那么流中的数据在算子之间转换的时候,会放入分布式的阻塞队列中。当消费者的阻塞队列满的时候,则会降低生产者的处理速度。 如上图所示,当Task C 的数据处…...
windows无法访问指定设备路径或文件怎么办?2个解决方案
有时候Win10电脑打不开程序或文件,windows无法访问指定设备路径或文件该怎么办?原因是什么呢?一般导致这种情况的出现,大多是因为我们的电脑缺乏相应的查看权限,我们只需要通过赋予权限就可以解决这个难题了。 操作环境…...
冷知识|鹤顶红还能用来修长城?
大家好,我是建模助手。 在上篇浅浅地蹭了波热点之后,我灵机一动,倒不如也搞一搞建筑方面的冷知识?冷热搭配,事半功倍... 问问大家,如果谈起古建筑,关键词都有什么?是庄严、震撼、壮…...
【GD32F427开发板试用】在IAR环境中移植RTX5
本篇文章来自极术社区与兆易创新组织的GD32F427开发板评测活动,更多开发板试用活动请关注极术社区网站。作者:吴金刚 0.前言 首先感谢极术社区和兆易创新给了这次试用GD32F427开发板的机会。 板子做的虽然简约,但是自带了GD-link所以一根USB…...
MySQl学习(从入门到精通15)
MySQl学习(从入门到精通15)第 18 章_MySQL 8 其它新特性1. MySQL 8 新特性概述1. 1 MySQL 8. 0 新增特性1. 2 MySQL 8. 0 移除的旧特性2. 新特性 1 :窗口函数2. 1 使用窗口函数前后对比2. 2 窗口函数分类2. 3 语法结构2. 4 分类讲解1. 序号函…...
前端构建工具 Vite
文章目录参考环境构建工具构建工具的主要功能目前主流的前端构建工具Vite为什么使用 Vite冷启动WebpackVite热更新优化热更新优化预构建依赖Webpack VS ViteVite 的缺点首屏性能懒加载与 Vite 相关的基本操作获取create-vite创建项目Project nameSelect a frameworkSelect a va…...
若依框架---PageHelper分页(十)
在前几天的文章中,我们介绍了PageHelper的分页方法,研读代码定位到了ExecutorUtil.pageQuery(...)方法,并阅读到了其中的部分代码。 今天我们将看到重要的SQL修改代码。 getPageSql 我们接着看代码: if (!dialect.beforePage(…...
苹果手机专用蓝牙耳机有哪些?与iphone兼容性好的蓝牙耳机
蓝牙耳机摆脱了线缆的束缚,在地以各种方式轻松通话。自从蓝牙耳机问世以来,一直是行动商务族提升效率的好工具,苹果产品一直都是受欢迎的数码产品,下面推荐几款与iphone兼容性好的蓝牙耳机。 第一款:南卡小音舱蓝牙耳…...
CS-TPGS;壳聚糖修饰维生素E;Chitosan-g-TPGS
Chitosan-g-TPGS,CS-TPGS壳聚糖修饰维生素E聚乙二醇1000琥珀酸酯外观呈现白色固体或者粘稠液体。长期保存需要在-20℃,避光,干燥条件下存放,注意取用一定要干燥,避免频繁溶冻。 维生素E聚乙二醇琥珀酸酯(简称TPGS)是维生素E的水溶性衍生物,由维生素E琥珀酸酯的羧基与…...
easyx的基本使用(万字解析)
easyx的基本使用一.基本框架1.创建文件2.创建窗体-initgraph,closegraph,getchar二.简单的绘制1.圆形-circle2.坐标系统-setorigin,setaspectratio三.简单图形1.绘制点-putpixel2.简单的直线-line3.矩形-rectangle4.椭圆-ellipse5.圆角矩形-roundrect6.扇形-pie7.圆弧-arc四.多…...
基于OpenCV 的车牌识别
基于OpenCV 的车牌识别 车牌识别是一种图像处理技术,用于识别不同车辆。这项技术被广泛用于各种安全检测中。现在让我一起基于 OpenCV 编写 Python 代码来完成这一任务。 车牌识别的相关步骤 1. 车牌检测:第一步是从汽车上检测车牌所在位置。我们将使用…...
C#【必备技能篇】Winform跨线程更新进度条的实例
文章目录实例一:【方便理解,常用!】源码:运行效果:实例二:【重在理解代码本身】源码:运行效果:参考:实例一:【方便理解,常用!】 跨线…...
(1分钟速通面试) 矩阵分解相关内容
矩阵分解算法--总结QR分解 LU分解本篇博客总结一下QR分解和LU分解,这些都是矩阵加速的操作,在slam里面还算是比较常用的内容,这个地方在isam的部分出现过。(当然isam也是一个坑,想要出点创新成果的话 可能是不太现实的 短期来讲 哈…...
this指向
(1)在全局环境中的this——window 无论是否在严格模式下,在全局执行环境中(在任何函数体外部)this 都指向全局对象。 "use strict"console.log(this); //windowconsole.log(thiswindow);//true (…...
安卓小游戏:小板弹球
安卓小游戏:小板弹球 前言 这个是通过自定义View实现小游戏的第三篇,是小时候玩的那种五块钱的游戏机上的,和俄罗斯方块很像,小时候觉得很有意思,就模仿了一下。 需求 这里的逻辑就是板能把球弹起来,球…...
7、单行函数
文章目录1 函数的理解1.1 什么是函数1.2 不同DBMS函数的差异1.3 MySQL的内置函数及分类2 数值函数2.1 基本函数2.2 角度与弧度互换函数2.3 三角函数2.4 指数与对数2.5 进制间的转换3 字符串函数4 日期和时间函数4.1 获取日期、时间4.2 日期与时间戳的转换4.3 获取月份、星期、星…...
华为机试题:HJ56 完全数计算(python)
文章目录博主精品专栏导航知识点详解1、input():获取控制台(任意形式)的输入。输出均为字符串类型。1.1、input() 与 list(input()) 的区别、及其相互转换方法2、print() :打印输出。3、整型int() :将指定进制…...
opencv——傅里叶变换、低通与高通滤波及直方图等操作
1、傅里叶变换a、傅里叶变换原理时域分析:以时间为参照进行分析。频域分析:相当于上帝视角一样,看事物层次更高,时域的运动在频域来看就是静止的。eg:投球——时域分析:第1分钟投了3分,第2分钟投…...
【NGINX入门指北】 进阶篇
nginx 进阶篇 文章目录nginx 进阶篇一、Nginx Proxy 服务器1、代理原理2、proxy代理3、proxy缓存一、Nginx Proxy 服务器 1、代理原理 正向代理 内网客户机通过代理访问互联网,通常要设置代理服务器地址和端口。 反向代理 外网用户通过代理访问内网服务器&…...
Python中关于@修饰符、yeild关键词、next()函数的基本功能简述
关于修饰符:其实就是将修饰符下面的函数当成参数传给它上面的函数。 def a(x):print(a)adef b():print(b) 其效果等价为: def a(x):print(a)def b():print(b)a(b())有个记忆诀窍,的下面哪个函数最近,谁就是儿子,谁就…...
湛江网站建设外包/seo专业实战培训
摘要:虚拟机Apache设置很多用户都遇到过,具体如何进行虚拟机Apache设置?怎样才能让虚拟机Apache设置达到最简单,最优化?本文为您讲解。Apache虚拟机设置有两种方法: 基于主机名的虚拟主机(一个IP地址&#…...
网站建设制作一个网站的费用/如何写软文推广产品
字符串与字节数组的转换 String str "helloworld"; byte data[] str.getBytes(); for(int x 0 ; x < data.length ; x) { data[x]- 32 ; System.out.print(datd[x] ,); } System.out.println(new String(data)); 通过程序可以发现,字节并不适合处…...
网站后台管理密码忘记/网站关键词优化推广哪家快
编辑 ~/.xine/catalog.cache 文件:sudo gedit ~/.xine/catalog.cache找到[/usr/lib/xine/plugins/1.1.4/xineplug_decode_real_audio.so]把 decoder_priority 后面的数字修改为 10 Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId1776898...
手机网站app/宁波营销型网站建设优化建站
首先,判断是否存在水平渐近线 当x→∞时,y→A(A∈R),说明存在水平渐近线当x\to\infty时,y\to A(A\in R),说明存在水平渐近线当x→∞时,y→A(A∈R),说明存在水平渐近线 若不存在水平渐近线,再判断是否存在铅直渐近线 当x→A(A∈R)时,y→∞,说明存在铅直渐近线当x\to…...
一家专门做衣服的网站/seo搜索引擎实战详解
子查询就是指在一个select语句中嵌套另一个select语句。 any,in,some,all分别是子查询关键词之一, any 可以与、>、>、结合起来使用,分别表示等于、大于、大于等于、小于、小于等于、不等于其中的任何一个数据。…...
网站的css文件夹/谷歌seo服务
10055 WA了两次之后好好or vice versa:反之亦然。另外,int型的最大为2^31-1(符号位)c#include <iostream> #include <stdio.h>using namespace std;#define lln long longint main() {lln a, b;lln t;while(~scanf(&q…...