ThinkSSL🔒 一键申购 5分钟快速签发 30天无理由退款 购买更放心 广告
1、mysql中的innodb为什么主键列使用较短的数据类型比较好? > InnoDB表是居于聚簇索引,聚簇索引对于主键查询有很高的性能,不过它的二级索引(非主键索引)中必须包含主键索引,所以如果主键列很大的话,其他的所有索引也会很大,使用较短的数据类型可以有效的减少索引的磁盘空间,提高索引的缓存效率 > 2、为什么主键不推荐使用UUID、md5、sha1生成的字符串? > 这些函败生成的新值会任意分布在很大的空间内,这会导致insert以及 —些SELECT语句变得很慢 1、因为插入值会随机地写到索引的不同位置,所以使INSERT语句更慢,这会导致页分裂、磁盘随机访问,以及对于聚簇存储引擎产生聚簇索引碎片, 2、SELECT语句会变得更慢,因为逻辑上相邻的行会分布在磁盘和内存的不同地方 3、随机值导致缓存对所有类型的査询语句效果都很差,因为会使得缓存赖以工作的访问局部性原理失效,如果整个数据集都一样的“热“,那么缓存任何一部分特定数据到内存都没有好处,如果工作集比内存大,缓存将会有很多刷新和不命中