五、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 锁的 ...
随机推荐
- 教孩子学编程 Python
教孩子学编程 Python 目录 第1 章 Python 基础:认识环境 111 认识Python 312 用Python 编写程序 513 运行Python 程序 514 本章小结 615 编程 ...
- Python - Django - 模板语言之自定义过滤器
自定义过滤器的文件: 在 app01 下新建一个 templatetags 的文件夹,然后创建 myfilter.py 文件 这个 templatetags 名字是固定的,myfilter 是自己起的 ...
- jenkins离线安装插件
2.jenkins离线安装插件 安装插件参照文档: https://blog.csdn.net/russ44/article/details/52266953 插件相关下载地址:http://upda ...
- 删除SQL约束的方法
在SQL数据库中,如果需要删除表约束,应该如何操作呢?下面就将为您介绍删除SQL表约束的方法,供您参考,希望对您有所帮助. --1)禁止所有表约束的SQL select 'alter table '+ ...
- AWS 数据传输加速(八)
AWS CloudFront 概述 一个CDN服务,加快网页和其它下载全球分布式网络缓存服务器 CloudFront通过全球性的边缘站点将内容缓存到世界各地实现CDN 在更邻近的位置提供更低的延迟,更 ...
- git的使用学习(一)git的简介和安装
Git简介 Git是什么? Git是目前世界上最先进的分布式版本控制系统(没有之一). Git有什么特点?简单来说就是:高端大气上档次! 那什么是版本控制系统? 如果你用Microsoft Word写 ...
- 14、OpenCV实现图像的空间滤波——图像锐化及边缘检测
1.图像锐化理论基础 1.锐化的概念 图像锐化的目的是使模糊的图像变得清晰起来,主要用于增强图像的灰度跳变部分,这一点与图像平滑对灰度跳变的抑制正好相反.而且从算子可以看出来,平滑是基于对图像领域的加 ...
- Python机器学习基础教程-第1章-鸢尾花的例子KNN
前言 本系列教程基本就是摘抄<Python机器学习基础教程>中的例子内容. 为了便于跟踪和学习,本系列教程在Github上提供了jupyter notebook 版本: Github仓库: ...
- centos docker 修改默认存储路径
1.修改配置 将--graph /mnt/docker添加在docker.service文件中的ExecStart字段后面,其中/mnt/docker为你需要修改的存储目录 $ vim /usr/li ...
- Jira 自定义工作流并设置触发器
一.添加修改工作流 打开 设置--问题--工作流 复制一个工作流,然后进去编辑页面 添加状态 增加转换动作 切换到文本,设置跳转过程中的事件 针对Stop Progress事件,修改跳转界面(界面需先 ...