Python学习打call第四十六天:MySQL数据库使用(二)

1.键的概念

  • :数据库中的键(key)又称为关键字,是关系模型中的一个重要概念,它是逻辑结构,不是数据库的物理部分;

  • 唯一键:即一个或者一组列,其中没有重复的记录,可以唯一标示一条记录;

  • 主键:属于唯一键,是一个比较特殊的唯一键,区别在于主键不可为空;

# id为主键  name是唯一键
create table Mark(id int not null primary key ,name varchar(250) unique key);

create table Mark(id int, name varchar(250), primary key(id), unique key(name));
  • 外键:一张表外键的值一般来说是另一张表主键的值,因此,外键的存在使得表与表之间可以联系起来;
create table students_to_teacher(to_id int, stu_id int, tea_id int, foreign key(stu_id) references students(id), foreign key(tea_id) references teacher(id));

2.索引的概念

  • 索引就像是一张表的目录,在查找内容之前可以先在目录中查找索引位置,以此快速定位查询数据,保存索引数据的文件一般会与保存数据的目录分开;

  • 索引应该构建在经常被用作查询条件的字段上;

3.索引类型

  • 普通索引:加速查询;
# 创建普通索引
create index 索引名称 on 表名(列名)

# 删除普通索引
drop index 索引名称 on 表名

# 查看索引
show index from 索引名
  • 唯一索引(UNIQUE KEY):加速查询 + 列值唯一(可以有null);
# 创建唯一索引
create unique index 索引名称 on 表名(列名)

# 删除唯一索引
drop unique  index 索引名称 on 表名
  • 主键索引(PRIMARY KEY):用于加速查询,只能有一个主键字段,不允许重复且不能为NULL;

  • 组合索引:多列值组成一个索引,专门用于组合搜索,其效率大于索引合并;

  • 全文索引:对文本的内容进行分词,进行搜索;

  • 空间索引:指依据空间对象的位置和形状或空间对象之间的某种空间关系按一定的顺序排列的一种数据结构;

4.引优化策略

  • 独立使用列,尽量避免其参与运算;
  • 左前缀索引:查询字段的时候,条件过滤时,最左前缀精确匹配;
  • 多列索引:AND 连接字段时适合多列索引,选择合适的索引次序,将选择性最高的放在左侧,范围匹配的放在右侧;

5.Innodb 存储引擎

  • 所有的InnoDB表的数据和索引存储于同一个表文件中,但是表数据和表结构分离;
    -rw-rw---- 1 mysql mysql    65 8月  27 14:31 db.opt
    -rw-rw---- 1 mysql mysql  8614 8月  27 14:31 students.frm
    -rw-rw---- 1 mysql mysql 98304 8月  27 14:31 students.ibd

    db.opt文件:主要用来存储当前数据库的默认字符集和字符校验规则
    students.frm文件:存放表结构的
    students.ibd文件:存储了当前表的数据和相关的索引数据
    因此,表数据和表结构分离, 每个表单独使用一个表文件来存储数据和索引
  • Mariadb默认的存储引擎是XtraDB,但是为了与MySQL兼容,因此也取名做InnoDB,因为MySQL的默认存储引擎是InnoDB;

  • 使用聚集索引(数据和索引在一起),也支持自适应hash索引,锁粒度为行级别,支持支持热备工具;

  • 支持事务的存储引擎,适合处理大量的短期事务;

6.MyISAM 存储引擎

  • 所有的MyISAM表的数据和索引存放在不同的文件中,表结构也分离;
-rw-rw---- 1 mysql mysql  10630 8月  27 13:12 user.frm
-rw-rw---- 1 mysql mysql    504 8月  27 13:15 user.MYD
-rw-rw---- 1 mysql mysql   2048 8月  27 14:30 user.MYI
user.frm:为表结构
user.MYD:为表数据
user.MYI:为表索引
  • 支持全文索引(fulltext index),压缩,空间函数;

  • 不支持事物,表级锁,适用于只读,读多写少;

7.MySQL的并发访问控制

  • 任何的数据集只要支持并发访问模型就必须基于锁机制进行访问控制;

  • 读锁:共享锁,允许给其他人读,不允许他人写;

  • 写锁:独占锁, 不允许其他人读和写;

  • 显示锁:用户手动请求读锁或写锁;

  • 隐式锁:由存储引擎自行根据需要加的,无需我们管理;

  • 给表施加锁机制

# lock tables 方式施加锁
lock tables 表名称 read   # 读锁
lock tables 表名称 write  # 写锁

# 给表解锁    
unlock tables;    

# flush tables 方式施加锁
flush tables 表名称 with read lock;   #读锁
flush tables 表名称 with write lock;  # 写锁

8.MySQL事务机制

  • 一组原子性的SQL查询,或多个SQL语句组成了一个独立的单元,要么这一组SQL语句全部执行,要么全部不执行;

事物日志:

  • 管理事物机制的日志;

  • redo日志:记录SQL执行的语句,这些SQL语句还没有同步到磁盘上,没有修改数据。如果数据奔溃,可以通过撤销SQL执行的语句来进行还原。但是,如果已经同步到磁盘上的SQL语句而言,就只能使用undo来回滚之前的数据了;

  • undo日志:记录没有执行SQL的样子,也就是记录修改数据之前的数据记录下来;

ACID机制:

  • automicity:原子性,整个事物中的所有操作要么全部成功提交,要么全部失败回滚;

  • consistency:一致性,数据库总是从一个一致性状态转化为另一个一致性状态;

  • isolation: 隔离性,事物不会相互影响,一个事物所作出的操作在提交之前,是不能为其他事物所见,隔离有多种级别,主要是为了并发;

  • durability:持久性,事物一旦提交,其所作的修改会保存在数据库中,不能丢失;

9.MySQL 查询缓存机制

  • 缓存的是查询语句的整个查询结果,是一个完整的select语句的缓存结果;

  • 哪些查询可能不会被缓存 :查询中包含UDF、存储函数、用户自定义变量、临时表、mysql库中系统表、或者包含列级别的权限表、有着不确定值的函数;

1.query_cache_min_res_unit:查询缓存分配内存块的最小的分配单位,较小的值较少内存浪费,但是会导致更加平凡的内存分配操作 ,较大的值会导致浪费

2.query_cache_limit:能够缓存的最大查询结果,对有较大结果的查询语句,建议在select中使用SQL_NO_CACHE

3.query_cache_size:查询缓存总共可用的内存空间,单位是字节,必须是1024整数倍

4.query_cache_type:ON , OFF , DEMAND

5.query_cache_wlock_invalidate:如果某个数据表被其他的连接锁定,是否仍然可以从查询缓存中返回结果,默认值为off,表示可以返回数据,on为不允许
  • 缓存命中率
缓存命中率计算公式: Qcache_hits / (Qcache_hits+Com_select)
缓存命中率.png

10.MySQL 日志分类

  • 查询日志 :query log ,一般不启用;
general_log = {ON|OFF}  # 是否启用查询日志
general_log_file = /logs/mysql/general_log  # 当log_output为FILE类型时,日志信息的记录位置;
log_output = {TABLE|FILE|NONE} 
log_output = TABLE,FILE
  • 慢查询日志:slow_query_log ,用于对执行速率较慢的SQL语句就像过滤,有利于SQL代码的优化;
1.执行时长超出指定时长的操作 
show global variables like 'long_query_time'; 查看指定的时长
set global long_query_time = 自定义时长

2.slow_query_log = {ON|OFF}:是否启用慢查询日志
set global slow_query_log = ON

3.slow_query_log_file = mariadb1-slow.log

# 过滤条件
4.log_slow_filter=admin,filesort,filesort_on_disk,full_join,full_scan,query_cache,query_cache_miss,tmp_table,tmp_table_on_disk 

5.log_slow_rate_limit = 1 指定记录速率

6.log_slow_verbosity = 指定内容级别
  • 错误日志:error log ,必须启用,二进制日志可以反应MySQL数据库的错误信息,用于调试;
# 错误日志信息产生的来源
    mysqld启动和关闭过程中输出的信息;
    mysqld运行中产生的错误信息;
    event scheduler运行一个event时产生的日志信息
    在主从复制架构中的从服务器上启动从服务器线程时产生的日志信息;

# 如何开启错误日志
    log_error = /path/to/somefile
    log_warnings = {ON|OFF}:是否记录警告信息于错误日志中; 

  • 二进制日志:binary log,用于通过'重新执行'日志文件中的记录的事件(SQL语句)来生成数据副本,也就是用于主从复制;
# 日志记录的格式分类
    基于“SQL语句”记录: statement
    基于“行”记录:row
    “混合模式” :mixed,系统自行判断


# 二进制日志文件的构成
    日志文件:mysql-bin.文件序号 
        例如: mysql-bin.000001
    索引文件:mysql-bin.index 
        例如:mysql-bin.index
  • 中继日志:relay log ,在主从复制架构中,从服务器用于保存从主服务器的二进制日志中读取到的时间;

  • 事务日志:transaction log ,事物日志由事物型存储引擎自行管理和使用,无需手动管理;

11.MySQL 备份策略的注意点

  • 可容忍丢失多少数据;

  • 恢复需要在多长时间内;

  • 备份的对象: 数据、二进制日志和InnoDB的事务日志、SQL代码(存储过程和存储函数、触发器、事件调度器等)、服务器配置文件;

  • 备份类型

1.站在数据集是否完整的角度上
    完全备份,部分备份 

2.站在完全备份的基础上
    增量备份,差异备份 

3.站在是否影响数据集读写的角度上
    热备份:在线备份,读写操作不受影响;
    温备份:在线备份,读操作可继续进行,但写操作不允许
    冷备份:离线备份,数据库服务器离线,备份期间不能为业务提供读写服务
    MyISAM存储引擎: 能够实现温备
    InnoDB存储引擎: 能够实现热备

4.站在数据存储角度上
    物理备份:直接复制数据文件进行的备份
    逻辑备份:从数据库中“导出”操作数据的SQL语句,再执行,实现备份

12.备份策略需要考虑的因素

  • 持锁的时长;

  • 备份过程时长;

  • 备份负载;

  • 恢复过程时长;

13.数据库备份具体解决方案

  • 数据:完全备份 + 增量备份
  • 备份:物理 + 逻辑

14.备份工具介绍

  • mysqldump:逻辑备份工具,适用于所有存储引擎,温备;但是对InnoDB存储引擎支持热备;
  • scp, tar 等文件系统工具:物理备份工具,适用于所有存储引擎;冷备;完全备份,部分备份,不适用于Innodb存储引擎;
  • lvm2的快照:几乎热备;借助于文件系统工具实现物理备份;
  • mysqlhotcopy: 几乎冷备;仅适用于MyISAM存储引擎

15.MySQL 半同步复制模型

  • 所谓的半同步复制指的是一台主节点有多个从节点,在众多的从节点之中有一个从节点在收到主节点的二进制日志信息之后,存储在中继日志中,执行中继日志后,给主节点一个反馈信息,直接点收到这个反馈信息之后,返回给执行这句SQL的ORM语句,表示数据已经存储完毕;

参考:https://www.9xkd.com/user/plan-view.html?id=4211738675

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容