五、MySQL系列之高级知识(五)
本篇 主要介绍MySQL的高级知识---视图、事件、索引等相关知识;
一、视图
在学习视图时我们需要什么是视图,视图有哪些好处以及视图的相关操作;
1.1 什么是视图?
关于视图通俗来讲就是一条select语句查询的结果集,本质而言就是一张虚表,与我们常说的快捷方式或者说软连接十分相似,它不存储具体的数据,而若基本表数据发生了改变,视图也会跟着改变。
1.2 视图的作用:
视图是一条select语句的结果集,故:
1、提高了重用性,类似一个函数,让我们想查询某些数据时,不需要每次敲复杂的select语句;
2、对数据库重构,却不影响程序的运行。即若不创建视图时,当我们修改基本表结构时,与Python交互时可能会出现问题。
3、提高了安全性。即通过视图我给不同用户呈现不同的数据。
4、让数据更加清晰,可读性更好
1.3 视图的相关操作
1、定义视图
语句: create view 视图名称 as select语句;
-- 定义视图
create view v_goods_info as
select g.*,c.name from goods as g left join goods_cates as c
on g.cate_id=c.id;
2、查看视图
视图时一张虚拟的表,故查看表所有的视图也会列出来;即 show tables ;
3、使用视图
视图的主要用途便是用于查询,而不是修改,注当修改多表定义的视图时,会容易报错;例如:
-- 查看视图
select * from v_goods_info; -- 修改视图时
update v_goods_info set name="皮皮虾我们走二代" where id=24; -- 报错 :ERROR 1288 (HY000): The target table v_goods_info of the UPDATE is not updatable
4、删除视图
drop view 视图名称
-- 删除视图
drop view v_goods_info
二、事务
同样对事务的学习我们也从什么是事务、事务有什么特性以及事务是如何操作的进行了解学习;
2.1 什么是事务?
所谓事务,它是一个操作序列,这些操作要么都执行,要么都不执行。它是一个不可分割的单位;
类似于银行转钱:假如用户A给用户B转200块钱,那么如果用户A给用户B转了钱之后,银行或者用户B出现了故障,导致用户A转了钱但是用户B没收到钱;这时就需要使用到事务,即:
用户A转钱和用户B收钱这两件事情要么都执行,要么都不执行;这样便会减少金钱纠葛了吧。
2.2 事务的四大特性:简称----ACID
即 原子性、一致性、隔离性、持久性;
原子性(Atomicity):即一个事务必须视为一个不可分割的最小工作单元,整个事务中的所有操作要么全部提交成功要么全部失败滚回。
一致性(Consistency):数据库总是从一个一致性状态转换到另外一个一致性的转态;即用户A转出钱和用户B收到钱是一致的;
隔离性(Isolation):一个事务在进行操作时会被上锁,其他的用户无法在其提交前进行修改;
持久性(Durability):一旦事务被提交,则其所有的修改会永久的保存到数据库。例如用户A给用户B转的钱钱就退不回来了。
2.3 事务如何操作
1、开启事务 --begin 或者 start transaction;
2、提交事务 -- commit;
3、滚回事务 -- rollback;
-- 比如有以上四个用户,让用户2给用户1转钱 -- 开启事务
start transaction; -- 用户2扣钱
update money set num=num-100 where id=2; -- 用户1收钱
update money set num=num+100 where id=1; -- 提交或者滚回
commit;
--或者
rollback;
三 、索引
3.1 索引是什么?
索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的应用指针;
3.2 索引的目的
提升查询效率,通常在实际开发过程中,查询的次数要远远大于修改,故提高查询效率十分关键;
通俗来讲:索引就像相当于一个字典的目录,若我们要查找一个字的时候,若从头到尾一路翻过去找则会超级麻烦,这时候了有了目录就方便且快速得多;索引也是同样的道理,可以大大提升查询效率,但是会占用一定的内存空间;
3.3 索引的原理
数据库的索引使用的 B-tree的查询方式。如下:

即:
数据库应该选择怎么样的方式来应对所有的问题呢?我们回想字典的例子,能不能把数据分成段,然后分段查询呢?最简单的如果1000条数据,1到100分成第一段,101到200分成第二段,201到300分成第三段……这样查第250条数据,只要找第三段就可以了,一下子去除了90%的无效数据。
3.3 索引的操作
1、查看索引 -- show index from 表名
2、创建索引 -- create index 索引名称 on 表名(字段名称(长度))
3、删除所有 -- drop index 索引名称 on 名称
小demo:
-- 创建一个表text_index
create table text_index (
num int unsigned not null );
创建表
# 通过python 想表中插入十万条数据
from pymysql import connect def main():
# 创建Connection连接
conn = connect(host='localhost',port=3306,database='jing_dong',user='root',password='mysql',charset='utf8')
# 获得Cursor对象
cursor = conn.cursor()
# 插入10万次数据
for i in range(100000):
cursor.execute("insert into test_index values('ha-%d')" % i)
# 提交数据
conn.commit() if __name__ == "__main__":
main()
插入十万条数据
-- 开启运行时间监测:
set profiling=1; -- 查找第1万条数据ha-99999
select * from test_index where title='ha-99999'; -- 查看执行的时间:
show profiles; -- 为表title_index的title列创建索引:
create index title_index on test_index(title(10)); -- 执行查询语句:
select * from test_index where title='ha-99999'; -- 再次查看执行的时间
show profiles;
从上述执行结果可以看出来:添加索引查询会大大建立查询时间,但是创建索引本身也会消耗一定的时间;
注:1、建立太多的索引将会影响更新和插入的速度,因为它需要同样更新每个索引文件。
2、建立索引会占用磁盘空间;
over~~~ 下篇介绍关于数据库权限设置和数据的备份~~~~~
五、MySQL系列之高级知识(五)的更多相关文章
- MySQL系列(一)--基础知识(转载)
安装就不说了,网上多得是,我的MySQL是8.0版本,可以参考:CentOS7安装MySQL8.0图文教程和MySQL8.0本地访问设置为远程访问权限 我的MySQL安装在阿里云上面,阿里云向外暴露端 ...
- 《tr命令-优化版》-linux命令五分钟系列之二十五
本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket. 为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. ...
- MySQL高级知识(十五)——主从复制
前言:本章主要讲解MySQL主从复制的操作步骤.由于环境限制,主机使用Windows环境,从机使用用Linux环境.另外MySQL的版本最好一致,笔者采用的MySQL5.7.22版本,具体安装过程请查 ...
- MySQL高级知识(五)——索引分析
前言:前面已经学习了explain(执行计划)的相关知识,这里利用explain对索引进行优化分析. 0.准备 首先创建三张表:tb_emp(职工表).tb_dept(部门表)和tb_desc(描述表 ...
- MySQL系列(五)---总结MySQL中的锁
MySQL中的锁 目录 MySQL系列(一):基础知识大总结 MySQL系列(二):MySQL事务 MySQL系列(三):索引 MySQL系列(四):引擎 概述 MyISAM支持表锁,InnoDB支持 ...
- MySQL高级知识系列目录
MySQL高级知识(一)——基础 MySQL高级知识(二)——Join查询 MySQL高级知识(三)——索引 MySQL高级知识(四)——Explain MySQL高级知识(五)——索引分析 MySQ ...
- MySQL 系列(五) 多实例、高可用生产环境实战
MySQL 系列(五) 多实例.高可用生产环境实战 第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 史上最屌.你不知道的数据库操作 第三 ...
- 如何选择普通索引和唯一索引《死磕MySQL系列 五》
系列文章 一.原来一条select语句在MySQL是这样执行的<死磕MySQL系列 一> 二.一生挚友redo log.binlog<死磕MySQL系列 二> 三.MySQL强 ...
- 五分钟,让你明白MySQL是怎么选择索引《死磕MySQL系列 六》
系列文章 二.一生挚友redo log.binlog<死磕MySQL系列 二> 三.MySQL强人"锁"难<死磕MySQL系列 三> 四.S 锁与 X 锁的 ...
随机推荐
- 生成有目录的pdf
生成有目录的pdf 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 https://jingyan.baidu.com/article/ff411625c2153512e48237a ...
- Form表单的传递与接收
目录 表单的构建 后端接收 创建model 用Model接收表单的后端 表单的构建 我才知道这个东西,在开发中经常遇到表单的情况.一下子提交一串内容.表单元素 form,里面的内容必须有name字段. ...
- jquery获取复选框checkbox的值
jQuery API : each(callback) :以每一个匹配的元素作为上下文来执行一个函数. :checked :匹配所有选中的被选中元素(复选框.单选框等,不包括select中的optio ...
- C# RESTful API
C# RESTful API REST 全称是 Representational State Transfer,有人说它是一种风格,并非一种标准,个人觉得挺有道理.它本身并没有创造新的技术.组件与服务 ...
- linux软件安装习惯
Linux 的软件安装目录是也是有讲究的,理解这一点,在对系统管理是有益的 /usr:系统级的目录,可以理解为C:/Windows/,/usr/lib理解为C:/Windows/System32./u ...
- Spring初解
1,关于spring容器: spring容器是Spring的核心,该 容器负责管理spring中的java组件, ApplicationContext ctx = new ClassPathXmlA ...
- PHP强制在微信中打开
if (!Func::isWx()) { exit('请在微信客户端打开链接'); } // 判断是否是微信 public static function isWx() { if ( strpos($ ...
- LeetCode 643. 子数组最大平均数 I(Maximum Average Subarray I)
643. 子数组最大平均数 I 643. Maximum Average Subarray I 题目描述 给定 n 个整数,找出平均数最大且长度为 k 的连续子数组,并输出该最大平均数. LeetCo ...
- [转帖]Redis未授权访问漏洞复现
Redis未授权访问漏洞复现 https://www.cnblogs.com/yuzly/p/11663822.html config set dirconfig set dbfile xxxx 一. ...
- [C++] 二叉树计算文件单词数
目录 前置技能 构造和遍历二叉树 文件的打开.读取和写入 需求描述 读取文件 构建二叉树 格式化输入输出 具体实现 main.cpp binarytree.h binarytree.cpp 使用二叉树 ...