1、mysql中的innodb为什么主键列使用较短的数据类型比较好?
> InnoDB表是居于聚簇索引,聚簇索引对于主键查询有很高的性能,不过它的二级索引(非主键索引)中必须包含主键索引,所以如果主键列很大的话,其他的所有索引也会很大,使用较短的数据类型可以有效的减少索引的磁盘空间,提高索引的缓存效率
>
2、为什么主键不推荐使用UUID、md5、sha1生成的字符串?
> 这些函败生成的新值会任意分布在很大的空间内,这会导致insert以及 —些SELECT语句变得很慢
1、因为插入值会随机地写到索引的不同位置,所以使INSERT语句更慢,这会导致页分裂、磁盘随机访问,以及对于聚簇存储引擎产生聚簇索引碎片,
2、SELECT语句会变得更慢,因为逻辑上相邻的行会分布在磁盘和内存的不同地方
3、随机值导致缓存对所有类型的査询语句效果都很差,因为会使得缓存赖以工作的访问局部性原理失效,如果整个数据集都一样的“热“,那么缓存任何一部分特定数据到内存都没有好处,如果工作集比内存大,缓存将会有很多刷新和不命中
- 前言
- 函数参考
- Socket 函数
- socket_accept
- socket_bind
- socket_clear_error
- socket_close
- socket_connect
- socket_create_listen
- socket_create_pair
- socket_create
- socket_getpeername
- socket_getsockname
- socket_last_error
- socket_listen
- socket_read
- socket_recv
- socket_select
- socket_send
- socket_set_block
- socket_set_nonblock
- SplQueue
- 魔术方法
- 魔术常量
- 杂项
- backlog的用处
- new self()和new static()的区别
- PHP变量的生命周期
- PHP抽象类
- 对象接口
- PHP中的常用关键字
- 常量
- 内存泄露
- global 与 $GLOBAL
- 简单说明CGI和动态请求是什么
- 设计模式
- 单例模式
- 工厂模式
- 适配器模式
- 策略模式
- 观察者模式
- 控制反转IoC简介
- session
- use_trans_sid
- auto_start
- session_id
- cookie_secure
- 面试
- 数据库相关
- 语句相关
- 索引相关
- 字段相关
- PHP相关
- 字符串相关
- 函数相关
- 运算符优先级相关
- 错误相关
- redis相关
- 10个常见的Redis面试"刁难"问题
- mysql
- MySQL中的锁
- MySQL存储引擎MyISAM 和 InnoDB的区别
- MySQL半同步复制
- explain 命令详解
- 索引
- 数据库事务
- MySQL和B树的那些事
- git
- github----向开源框架提交pr的过程
- 推荐博客
- linux
- 命令
- free
- 高并发
- 抢购/秒杀功能
- 算法
- 一致性Hash算法