####共享锁(shared lock)和排它锁(exclusive lock)
也叫读锁(red lock)和写锁(write lock)
####多版本并发控制,(Multi-Version Concurrency Control)
InnoDB的MVCC,通过在每行后面保存2个隐藏列,创建时间和过期时间,类似拉链表,实际存的是系统版本号
####InnoDB存储引擎
+ 事务。如果不需要事务,主要是select和insert,那么可以用MyISAM
+ 备份。(在线热备份)
+ 崩溃恢复。MyISAM崩溃后损坏的概率比InnoDB高很多

修改表的存储引擎

先创建新表,用新的引擎,再把数据导入

服务器分类

  • SMP(Symmetric Multi-Processor),对称单节点多核
  • MPP(Massive Parallel Processing),多节点多核

RAID

Redundant Array of Independent Disks(独立磁盘冗余阵列),简称磁盘阵列


####连接mysql
mysql -hlocalhost -uroot -p
####查看表信息
show table status like 'user'


####服务器运行状态
show global status
####查看有哪些线程在运行
show full processlist
show processlist\G,(垂直方式输出)
####基准测试套件
Mysql基准测试套件(Benchmark Suite)是基于Perl开发的,在安装目录下的sql-bench子目录中
####慢查询日志是否开启
SHOW VARIABLES LIKE 'slow_query_log';
####慢查询日志存放位置
SHOW VARIABLES LIKE 'slow_query_log_file';


####尽量避免NULL
可为NULL的列使得索引,索引统计和值比较都更复杂。要建索引的列避免NULL
####timestamp和datetime
+ timestamp包含不同时区的时间,空间效率更高
+ datetime保存更大范围,1001到9999年

范式和反范式

  • 范式的表更小,很少有多余的数据,更少需要distinct和group by
  • 缺点是经常需要关联查询
  • 反范式所有数据都在一张表中,可以避免关联查询
  • 缺点是查询最差情况要全表扫描

加快alter table操作的速度

  • 先再1台不提供服务的机器上alter,然后和提供服务的主库切换
  • 建一张新表,导完数据再重命名替换

####B-Tree索引
适用于全键值,键值范围,键前缀。如果查询中有某个列的范围查询,则其右边的列都无法使用索引
####哈希索引(Memory引擎)
对每行数据的索引列计算一个hash code,将所有的哈希码存储在索引中,同时在哈希表中保存指向每行数据的指针。
#####创建自定义的哈希索引
key很长的时候比如url,where查询条件包括url常量值和经过哈希函数处理后的key,可以使用触发器在insert和update时维护哈希值。不包含常量值会引起哈希冲突
####空间数据索引(R-Tree)
MyISAM支持空间索引,地理数据存储
####聚簇索引
聚集索引将索引和数据保存在同一个b-tree中
####数据文件的结构
在data目录中,.MYD是数据文件,.MYI是索引文件,.frm是结构文件
####explain
使用explain加查询语句,可以查看是否用上索引,有没有做全表扫描等
```bash
mysql> explain select * from user;
+----+-------------+-------+------+---------------+------+---------+------+------+-------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+------+---------------+------+---------+------+------+-------+
| 1 | SIMPLE | user | ALL | NULL | NULL | NULL | NULL | 4 | |
+----+-------------+-------+------+---------------+------+---------+------+------+-------+
1 row in set (0.01 sec)
```
####optimize
删除大量数据后,容易产生碎片,会使数据文件大小不变(MYD和MYI大小没变),影响插入。optimize可以清除碎片,把分散存储的数据和索引重新挪到一起,操作时会加锁
####使用索引原则
+ 尽可能将要做范围查询的列放到索引后面,以便优化器能用尽可能多的索引列。查询只能使用索引的最左前缀,知道遇到第一个范围条件列
+ 可以的条件下,可以把范围查询替换成in(1,2,3)的等值查询


####分而治之
比如删除数据的时候,一次删除大量数据,可能一次锁住很多数据,阻塞其他查询。可以定时任务每个月删除数据,再每次到达一定行后删除,避免一次性删除大量数据。
####关联查询using
select * from a join b on a.id=b.id,可以简写为
select * from a join b using(id)
####分区表
通过分区函数来过滤一些分区
####存储过程
存储过程速度更快,因为无需网路通信开销,解析开销和优化器开销

mysql概念特性和优化的更多相关文章

  1. MySQL · 特性分析 · 优化器 MRR & BKA【转】

    MySQL · 特性分析 · 优化器 MRR & BKA 上一篇文章咱们对 ICP 进行了一次全面的分析,本篇文章小编继续为大家分析优化器的另外两个选项: MRR & batched_ ...

  2. mysql笔记04 MySQL高级特性

    MySQL高级特性 1. 分区表:分区表是一种粗粒度的.简易的索引策略,适用于大数据量的过滤场景.最适合的场景是,在没有合适的索引时,对几个分区进行全表扫描,或者是只有一个分区和索引是热点,而且这个分 ...

  3. MySQL · 引擎特性 · InnoDB 事务子系统介绍

    http://mysql.taobao.org/monthly/2015/12/01/ 前言 在前面几期关于 InnoDB Redo 和 Undo 实现的铺垫后,本节我们从上层的角度来阐述 InnoD ...

  4. MySQL之查询性能优化(二)

    查询执行的基础 当希望MySQL能够以更高的性能运行查询时,最好的办法就是弄清楚MySQL是如何优化和执行查询的.MySQL执行一个查询的过程,根据图1-1,我们可以看到当向MySQL发送一个请求时, ...

  5. [MySQL Reference Manual] 8 优化

    8.优化 8.优化 8.1 优化概述 8.2 优化SQL语句 8.2.1 优化SELECT语句 8.2.1.1 SELECT语句的速度 8.2.1.2 WHERE子句优化 8.2.1.3 Range优 ...

  6. MySQL · 引擎特性 · InnoDB 崩溃恢复过程

    MySQL · 引擎特性 · InnoDB 崩溃恢复过程 在前面两期月报中,我们详细介绍了 InnoDB redo log 和 undo log 的相关知识,本文将介绍 InnoDB 在崩溃恢复时的主 ...

  7. 腾讯云数据库团队:浅谈如何对MySQL内核进行深度优化

    作者介绍:简怀兵,腾讯云数据库团队高级工程师,负责腾讯云CDB内核及基础设施建设:先后供职于Thomson Reuters和YY等公司,PTimeDB作者,曾获一项发明专利:从事MySQL内核开发工作 ...

  8. 第 8 章 MySQL 数据库 Query 的优化

      前言: 在之前“影响 MySQL 应用系统性能的相关因素”一章中我们就已经分析过了Query语句对数据库性能的影响非常大,所以本章将专门针对 MySQL 的 Query 语句的优化进行相应的分析. ...

  9. MySQL 数据库 Query 的优化

    理解MySQL的Query Optimizer MySQL Optimizer是一个专门负责优化SELECT 语句的优化器模块,它主要的功能就是通过计算分析系统中收集的各种统计信息,为客户端请求的Qu ...

随机推荐

  1. java基础-关键词super与this

    转发:itbooks this是调用自己本身的构造函数,而super是调用父类中的构造函数. 这两个关键词是用在构造函数中的,这两个关键词的设计也是对封装特性的一种考虑,避免编写不必要的重复代码. c ...

  2. Bootstrap 文件上传插件 FileInput的使用问题

    : 在使用bootstrap的文件上传插件fileinput http://plugins.krajee.com/file-input的预览功能时,删除预览图片在 bootstrap 模态框中没有用, ...

  3. 3.redis设计与实现--字典

    1.包括三个结构体:字典结构体+哈希表结构体+哈希节点结构体 2.如何解决哈希冲突? 答:redis使用的是链地址法来解决哈希冲突的,每个链表节点有一个next指针,最新加入的节点会放在链表的头部. ...

  4. C11关键字&字面值改善

    1.原始字面值改善 原始字面值可以直接表示字符串的实际含义,但是一些特殊字符就需要转义. std::string str = "D:\A\B\test.txt"; std::cou ...

  5. Zepto学习笔记

    Zepto和jQuery的很多API都很一致,思路也很相似,我不会全都整理出来,只是把一些平时用到了的或者不同的地方需要注意一下的地方总结出来.另外,Zepto现在还不是很成熟,无论是对大小写的敏感还 ...

  6. 【BZOJ】3052: [wc2013]糖果公园 树分块+带修改莫队算法

    [题目]#58. [WC2013]糖果公园 [题意]给定n个点的树,m种糖果,每个点有糖果ci.给定n个数wi和m个数vi,第i颗糖果第j次品尝的价值是v(i)*w(j).q次询问一条链上每个点价值的 ...

  7. 读书笔记 ~ Python黑帽子 黑客与渗透测试编程之道

    Python黑帽子  黑客与渗透测试编程之道   <<< 持续更新中>>> 第一章: 设置python 环境 1.python软件包管理工具安装 root@star ...

  8. Spring Tool Suite 配置和使用

    Spring Tool Suite使用 1.下载地址: http://spring.io/tools 2.配置字符编码:UTF-8 默认的编码是ISO-8859-1的西欧文字编 1.windows-- ...

  9. ogg数据初始化历程记录

    之前,源端数据表结构发生改变,不知道前面的同事是怎么搞得(生成的数据定义文件不对,还是没有把进程启动),造成进程停止20天,然后重启复制进程,对比源端和目标端数据有差异(总共差10000多条数据),问 ...

  10. Git和Github简单教程【转】

    转自:https://www.cnblogs.com/schaepher/p/5561193.html#clone 原文链接:Git和Github简单教程 网络上关于Git和GitHub的教程不少,但 ...