Python11/26--mysql之视图/触发器/事务/存储过程
视图:
1.什么是视图
视图就是通过查询得到一张虚拟表,然后保存下来,下次用的时候直接使用即可
2.为什么用视图
如果要频繁使用一张虚拟表,可以不用重复查询
3.如何用视图
select * from 表1 inner join 表2 on 表1.id = 表2.表1_id ;
注意:1.在硬盘中,视图只有表结构文件,没有表数据文件
2.视图通常是用于插叙,尽量不要修改视图中的数据
触发器:
1.什么是触发器
在满足对某张表数据的增、删、改的情况下(没有查),自动触发的功能称之为触发器
2.为何要用触发器?
触发器专门针对我们对某张表数据的增、删、改的行为,这类行为一旦执行就会启动触发器
,即自动运行另外一段sql代码
3.创建触发器语法
create trigger 触发器的名字 after(也可以用before代表在之前触发) insert(可以换成delete,update) on 表名 for each row(结尾这三个是固定语法) 释义:在这个表名插入一条记录 之后触发一条触发器的行为
begin
当上门的create 触发器 触发时,自动执行 这段sql代码。。
end
触发器这样命名会好一点: 触发器名_after_insert_哪张表名
事务:
1.什么是事务
开启一个事务可以包含一些sql语句,这些sql语句要么同时成功,要么都不能成功,称之为事务的 原子性
2.事务的作用
可以监测一系列操作的安全性、准确性,可以对事务控制范围内的数据进行回滚等操作
3.怎么使用事务
start transaction #开启事务
开始执行sql 语句。
可以执行rollback 回滚到修改数据之前的状态
在没有执行commit之前这些修改的任何操作数据都不会刷新到硬盘
存储过程:
1.定义:存储过程包含了一系列可执行的sql语句,存储过程存放于mysql中,通过调用他的名字可以执 行其内部的一堆sql
2.三种开发模型:
1、应用程序:只需要开发应用程序的逻辑
mysql:编写好存储过程,用来给应用程序调用
优点:开发效率,执行效率都高
缺点:考虑到人为因素、跨部门沟通等问题,会导致扩展性差
2、应用程序:除了开发应用程序的逻辑,还需要编写原生sql
mysql:
优点:比方式1 拓展性高(非技术层面)
缺点:开发效率、执行效率都不如方式1,编写原生sql太过于复杂,需要考虑sql语句的优化
3.应用程序:开发应用程序的逻辑,不需要编写原生的sql,基于别人编写好的框架来处理数据,
mysql:
优点:不用再编写纯生sql,这意味着开发效率要比方式2高 ,同时拓展性也高
缺点:执行效率连方式2 都不如
3.创建存储过程:
create procedure 存储过程名(可传参)
begin
sql语句
end
call 存储过程名(可传参) # call 是调用
2
Python11/26--mysql之视图/触发器/事务/存储过程的更多相关文章
- MySQL拓展 视图,触发器,事务,存储过程,内置函数,流程控制,索引,慢查询优化,数据库三大设计范式
视图: 1.什么是视图 视图就是通过查询得到一张虚拟表,然后保存下来,下次直接使用即可 2.为什么要用视图 如果要频繁使用一张虚拟表,可以不用重复查询 3.如何使用视图 create view tea ...
- MySQL 视图触发器事务存储过程函数
事务 致命三问 什么是事务:开启了一个包含多条SQL语句的事务,这些SQL语句要么都执行成功,要么有别想成功:例如A向B转账,二人账户并不属于一家银行,在转账过程中由于网络问题,导致A显示转账 成功 ...
- mysql 查询表,视图,触发器,函数,存储过程
1. mysql查询所有表: SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '数据库名' AND TAB ...
- MySQL 视图 触发器 事务 存储过程 函数 流程控制 索引与慢查询优化
视图 1.什么是视图? 视图就是通过查询得到的一张虚拟表,然后保存下来,下次可直接使用 2.为什么要使用视图? 如果要频繁使用一张虚拟表,可以不用重复查询 3.如何使用视图? create view ...
- MySQL——视图/触发器/事务/存储过程/函数/流程控制
一 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的 ...
- MySQL视图,触发器,事务,存储过程,函数
create triggr triafterinsertcmdlog after insert on cmd_log FOR EACH ROW trigger_body .#NEW : 代表新的记录 ...
- MySQL_视图/触发器/事务/存储过程/函数
视图.触发器.事务.存储过程.函数 视图 视图是一个虚拟表(非真实存在),其本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用名称即可获取结果集,可以将该结果集当作表来使用 #创建视 ...
- python mysql 视图 触发器 事物 存储过程 用户授权 数据备份还原
###################总结########### 视图是一个虚拟表(非真实存在) 是跑在内存中的表,真实表是在硬盘上的表 使用视图我们可以把查询过程中的临时表摘出来,保存下来,用视图去 ...
- Mysql学习---视图/触发器/存储过程/函数/执行计划/sql优化 180101
视图 视图: 视图是一个虚拟表(非真实存在),动态获取数据,仅仅能做查询操作 本质:[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用.由 ...
随机推荐
- 无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用) ...ubuntu 18.04 安装vim遇到的错误
安装vim: sudo apt-get install vim-gtk 问题: E:无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用) E:无法锁定管理目录(/ ...
- k8s学习笔记之五:Pod资源清单spec字段常用字段及含义
第一章.前言 在上一篇博客中,我们大致简述了一般情况下资源清单的格式,以及如何获得清单配置的命令帮助,下面我们再讲解下清单中spec字段中比较常见的字段及其含义 第二章.常用字段讲解 spec.con ...
- 10-安装es
1.安装jdk(jdk要求1.8.20或1.7.55以上) 2.上传es安装包 3.解压es tar -zxvf elasticsearch-2.3.1.tar.gz -C /opt/app/ 4.e ...
- HTML-全局属性 / 事件属性(转)
拷贝自:< http://www.runoob.com > HTML 全局属性 New : HTML5 新属性. 属性 描述 accesskey 设置访问元素的键盘快捷键. class 规 ...
- 使用openpyxl复制整张sheet
通过无能的baidu逛了一圈,发现有两三段能用的代码,不过参考之下,发现还有不足的: 不能拷贝有合并格式的sheet.没有拷贝cell的相关格式(填充.边框.对齐)等参数 所以通过bing继续发掘,最 ...
- Linux网络编程学习(四) -----守护进程的建立(第三章)
本文介绍一个例程daemon_init() #include <sys/types.h> #include <signal.h> #include <unistd.h&g ...
- [PHP]误读支付宝接口可能引发的乌龙
------------------------------------------------------------------------------------ 之所以发现这个坑,源起项目中的 ...
- IntelliJ IDEA——SVN的配置及使用
服务端:VisualSVN-Server-3.9.1-x64 下载地址:https://www.visualsvn.com/server/download/ TortoiseSVN 安装 下载地址:h ...
- OpenStack 安装:nova服务
上一篇介绍了glance,并且成功创建了一个镜像,这一篇介绍Nova. 首先创建Nova用户,需要记得先source环境变量,然后创建Nova用户,并设置密码为nova [root@linux-nod ...
- MQTT服务器本地搭建
1.1 初认识MQTT协议. 2.1 下载压缩包 前往EMQ下载地址:http://emqtt.com/downloads ,下载您的系统的版本,一般选择稳定版. 2.2 解压并运行 C:\Users ...