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

数据库-MySQL之数据库必知必会22-26章

第 22 章 使用视图

视图是虚拟的表。与包含数据的表不一样,视图只包含使用时动态检索数据的查询。
在这里插入图片描述
使用视图
视图用CREATE VIEW语句来创建。
使用SHOW CREATE VIEW viewname;来查看创建视图的语句。
用DROP删除视图,其语法为DROP VIEW viewname;。
更新视图时,可以先用DROP再用CREATE,也可以直接用CREATE OR REPLACE VIEW。如果要更新的视图不存在,则第2条更新语句会创建一个视图;如果要更新的视图存在,则第2条更新语句会替换原有视图。
利用视图简化复杂的联结
可以将复杂联结创建为视图 然后在视图中进行操作

第23章 使用存储过程

  1. 经常会有一个完整的操作需要多条语句才能完成。执行这个操作需要针对许多表的多条MySQL语句。此外,需要执行的具体语句及其次序也不是固定的可以创建存储过程。
  2. 存储过程有3个主要的好处,即简单、安全、高性能
  3. MySQL执行存储过程的语句为CALL。CALL接受存储过程的名字以及需要传递给它的任意参数。
    在这里插入图片描述

创建存储过程

示例:
在这里插入图片描述

删除存储过程

在这里插入图片描述

使用参数

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
onumber定义为IN,因为订单号被传入存储过程。ototal定义
为OUT,因为要从存储过程返回合计。

建立智能存储过程

使用IF语句
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
–为注释

第24章 使用游标

需要在检索出来的行中前进或后退一行或多行。这就是使用游标的原因。游标(cursor)是一个存储在MySQL服务器上的数据库查询,它不是一条SELECT语句,而是被该语句检索出来的结果集。在存储了游标之后,应用程序可以根据需要滚动或浏览其中的数据
游标的使用步骤
在这里插入图片描述
创建游标
在这里插入图片描述
这个存储过程并没有做很多事情,DECLARE语句用来定义和命
名游标,这里为ordernumbers。存储过程处理完成后,游标就
消失(因为它局限于存储过程)。

第25章 使用触发器

想要某条语句(或某些语句)在事件发生时自动执行,shiy

 唯一的触发器名;
 触发器关联的表;
 触发器应该响应的活动(DELETEINSERTUPDATE);
 触发器何时执行(处理之前或之后)。

在这里插入图片描述
只有表才支持触发器,视图不支持(临时表也不支持)

不同触发器的原理

INSERT触发器
在INSERT触发器代码内,可引用一个名为NEW的虚拟表,访问被插入的行;
 在BEFORE INSERT触发器中,NEW中的值也可以被更新(允许更改被插入的值);
 对于AUTO_INCREMENT(自增)列,NEW在INSERT执行之前包含0,在INSERT执行之后包含新的自动生成值
DELETE触发器
在DELETE触发器代码内,你可以引用一个名为OLD的虚拟表,访问被删除的行;OLD中的值全都是只读的
UPDATE触发器
 在UPDATE触发器代码中,你可以引用一个名为OLD的虚拟表访问以前(UPDATE语句前)的值,引用一个名为NEW的虚拟表访问新更新的值;
 在BEFORE UPDATE触发器中,NEW中的值可能也被更新(允许更改将要用于UPDATE语句中的值);
 OLD中的值全都是只读的,不能更新。

第 26 章 管理事务处理

InnoDB支持事务处理
事务处理(transaction processing)可以用来维护数据库的完整性,它保证成批的MySQL操作要么完全执行,要么完全不执行。
概念

  • 事务(transaction)指一组SQL语句;
  • 回退(rollback)指撤销指定SQL语句的过程;
  • 提交(commit)指将未存储的SQL语句结果写入数据库表;
  • 保留点(savepoint)指事务处理中设置的临时占位符(placeholder),你可以对它发布回退(与回退整个事务处理

控制事务处理

事务开始
在这里插入图片描述
ROLLBACK
回退从某一点到Rolllback的所有操作
使用COMMIT
在这里插入图片描述

使用事务处理块来
保证订单不被部分删除。最后的COMMIT语句仅在不出错时写出更改。如
果第一条DELETE起作用,但第二条失败,则DELETE不会提交
使用保留点
回退部分事务处理


http://www.kler.cn/news/155770.html

相关文章:

  • 工具网站:随机生成图片的网站
  • Fiddler抓包工具之fiddler的composer可以简单发送http协议的请求
  • 【数据库】数据库元素的层次,树形结构的下的多粒度加锁,以及幻象的正确处理
  • FIORI /N/UI2/FLP 始终在IE浏览器中打开 无法在缺省浏览器中打开
  • Facebook做外贸推广如何?
  • vue3高雅的使用useDialog
  • 设计模式-结构型模式之代理设计模式
  • 前端分片上传
  • TimeGPT:时序预测领域终于迎来了第一个大模型
  • 栈和队列OJ题——15.循环队列
  • Docker—更新应用程序
  • 【开源存储】glusterfs分布式文件系统部署实践
  • 学习TypeScrip5(函数扩展)
  • 数据结构之堆排序以及Top-k问题详细解析
  • SSM框架(三):SpringMVC
  • 【智能家居】四、网络服务器线程控制功能点
  • (一)WtBtRunner回测大体流程
  • [数据库]阿里云postgres数据库备份恢复
  • 30岁左右的简历模板精选7篇
  • Redis常见类型
  • 【c语言:常用字符串函数与内存函数的使用与实现】
  • 计组-指令周期、机器周期、时钟周期以及其它的各种周期
  • 使用单体锁和分布式锁解决超卖问题
  • MYSQL报错 [ERROR] InnoDB: Unable to create temporary file; errno: 0
  • WPF实战项目十九(客户端):修改RestSharp的引用
  • 【Docker】容器数据持久化及容器互联
  • ThinkPHP的方法接收json数据问题
  • 【数据挖掘】国科大刘莹老师数据挖掘课程作业 —— 第三次作业
  • Vue3中teleport如何使用
  • 详解Spring对Mybatis等持久化框架的整合