本篇 主要介绍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系列之高级知识(五)的更多相关文章

  1. MySQL系列(一)--基础知识(转载)

    安装就不说了,网上多得是,我的MySQL是8.0版本,可以参考:CentOS7安装MySQL8.0图文教程和MySQL8.0本地访问设置为远程访问权限 我的MySQL安装在阿里云上面,阿里云向外暴露端 ...

  2. 《tr命令-优化版》-linux命令五分钟系列之二十五

    本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket. 为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. ...

  3. MySQL高级知识(十五)——主从复制

    前言:本章主要讲解MySQL主从复制的操作步骤.由于环境限制,主机使用Windows环境,从机使用用Linux环境.另外MySQL的版本最好一致,笔者采用的MySQL5.7.22版本,具体安装过程请查 ...

  4. MySQL高级知识(五)——索引分析

    前言:前面已经学习了explain(执行计划)的相关知识,这里利用explain对索引进行优化分析. 0.准备 首先创建三张表:tb_emp(职工表).tb_dept(部门表)和tb_desc(描述表 ...

  5. MySQL系列(五)---总结MySQL中的锁

    MySQL中的锁 目录 MySQL系列(一):基础知识大总结 MySQL系列(二):MySQL事务 MySQL系列(三):索引 MySQL系列(四):引擎 概述 MyISAM支持表锁,InnoDB支持 ...

  6. MySQL高级知识系列目录

    MySQL高级知识(一)——基础 MySQL高级知识(二)——Join查询 MySQL高级知识(三)——索引 MySQL高级知识(四)——Explain MySQL高级知识(五)——索引分析 MySQ ...

  7. MySQL 系列(五) 多实例、高可用生产环境实战

    MySQL 系列(五) 多实例.高可用生产环境实战   第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 史上最屌.你不知道的数据库操作 第三 ...

  8. 如何选择普通索引和唯一索引《死磕MySQL系列 五》

    系列文章 一.原来一条select语句在MySQL是这样执行的<死磕MySQL系列 一> 二.一生挚友redo log.binlog<死磕MySQL系列 二> 三.MySQL强 ...

  9. 五分钟,让你明白MySQL是怎么选择索引《死磕MySQL系列 六》

    系列文章 二.一生挚友redo log.binlog<死磕MySQL系列 二> 三.MySQL强人"锁"难<死磕MySQL系列 三> 四.S 锁与 X 锁的 ...

随机推荐

  1. Python第一阶段01

    1.变量: name = "sisi" print(name) age = print(age) 2.常量: PIE = 3.1415926 3.注释: # password = ...

  2. IE浏览器提示打印控件未安装的一些原因

    打印控件未安装!点击这里执行安装,安装后请刷新页面或重新进入.--该提示是写在LodopFuncs.js里的.相关本博客其他博文:提示“Web打印服务CLodop未安装启动”的各种原因和解决方法.C- ...

  3. 如何在Windows Server 2008 R2中更改桌面图标

    如何在Windows Server 2008 R2中更改桌面图标 Windows Server 2008 R2 已经在 MSDN 和 TechNet Plus 订阅上公布,gOxiA 在第一时间下载并 ...

  4. python解包

    概念 python的解包可以这样来理解:把元素给拆分并把其赋值给自己所需要的变量,因此元素应该是一个可迭代对象. 形式 简单版本 下面展示的是解包的基本形式,根据长度赋值给对应多的变量. name_l ...

  5. pt-osc 变更时遇到 “MySQL error 1300” 报错问题解决

    目的 线上一张表的字段长度变更 `sGuid` varchar(255) DEFAULT NULL COMMENT 'sGuid' => `sGuid` varchar(512) DEFAULT ...

  6. QT学习之usb摄像头采集(Opencv+QT)[cvCapture,IplImage,QImage]

    参考自:http://blog.chinaunix.net/uid-23381466-id-3826748.html 将Opencv中的cvCaptureFromCAM不断获得摄像头采集到的图像数据, ...

  7. 【GStreamer开发】GStreamer基础教程12——流

    目标 直接播放Internet上的文件而不在本地保存就被称为流播放.我们在前面教程里已经这样做过了,使用了http://的URL.本教程展示的是在播放流的时候需要记住的几个点,特别是: 如何设置缓冲 ...

  8. 查看Mysql是否开启binlog

    show variables like 'log_bin';

  9. smarty中常用的流程控制逻辑

    if else {if $age > 18} <div>年满十八岁!</div> {else if $age > 16} <div>年满十六岁!< ...

  10. sublime3 安装markdown插件

    sublime3 安装markdown插件 第一步安装package control 自动安装package control 手动安装package control 安装具体的markdown相关的p ...