第一个关键点:数据是存储在主键中,必须显式定义主键,如果不显式定义主键会出现两种情况: ·第一种情况是在使用 DTS 来传输数据时,无法判断数据是不是重复,是不是唯一的。主键的定义是非空、唯一。 ·第二种情况是把RDS for MySQL的备份还原到线下的数据时,没有主键的表,读取时字段对不上。因为阿里的MySQL, 为了避免出现没有定义主键而导致的问题,默认隐式的增加一个字段,把物理备份还原到本地时,这张表会多出一个字段,会导致恢复后这张表不可访问。 第二个关键点:表的每个数据块大小都是16KB,分支节点也是16KB,分支节点上的条目数越多,树越扁,树高越小,查询的越快。因为根和分支节点都需要内存运行,树高越高,需要读的16KB的块数就越多,导致查询会更慢。块的尺寸一定的情况下,里面带的条目数越多,树高越小,访问数据的代价越低。条目数取决于主键的数据类型,int类型4个字节,big int是8个字节,如果使用的是字符串,在utf8字符集的情况下,是char类型,要3个字节。所以关键点是主键尽量使int或者是big int这种整形,本身它很小,通常情况下一个16KB的块能放几百个int类型的条目,树高很容易控制在很小。 第三个关键点:本身它是一棵平衡树,平衡树的要求就在于,从根到任何一个叶子节点高度都要一样,树高是固定值,这棵树不断地被增、删、改的情况下,为了保证根到叶子节点的树高一致,建议用auto_increment正向递增或者使用sequence,比如在有 PolarDB-X 场景下,建议采用sequence对象来获取主键自增值,保证每次的写入的操作,尤其是插入操作,性能一致。
答复内容摘自《深入MySQL实战》,这本电子书收录开发者藏经阁 下载连接:https://developer.aliyun.com/topic/download?id=1167
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。