MySQL的InnoDB表要建议用自增列做主键_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2441 | 回复: 0   主题: MySQL的InnoDB表要建议用自增列做主键        下一篇 
    本主题由 hui.chen 于 2014-11-5 15:58:13 移动
tngou
注册用户
等级:中校
经验:2433
发帖:192
精华:15
注册:2014-4-28
状态:离线
发送短消息息给tngou 加好友    发送短消息息给tngou 发消息
发表于: IP:您无权察看 2014-11-4 9:58:34 | [全部帖] [楼主帖] 楼主   主页

    我们先了解下InnoDB引擎表的一些关键特征:

  •  InnoDB引擎表是基于B+树的索引组织表(IOT);
  •  每个表都需要有一个聚集索引(clustered index);
  •  所有的行记录都存储在B+树的叶子节点(leaf pages of the tree);
  •  基于聚集索引的增、删、改、查的效率相对是最高的;
  •  如果我们定义了主键(PRIMARY KEY),那么InnoDB会选择其作为聚集索引;
  •  如果没有显式定义主键,则InnoDB会选择第一个不包含有NULL值的唯一索引作为主键索引;
  •  如果也没有这样的唯一索引,则InnoDB会选择内置6字节长的ROWID作为隐含的聚集索引(ROWID随着行记录的写入而主键递增,这个ROWID不像ORACLE的ROWID那样可引用,是隐含的)。

综上总结,如果InnoDB表的数据写入顺序能和B+树索引的叶子节点顺序一致的话,这时候存取效率是最高的,也就是下面这几种情况的存取效率最高:

  •  使用自增列(INT/BIGINT类型)做主键,这时候写入顺序是自增的,和B+数叶子节点分裂顺序一致;
  •  该表不指定自增列做主键,同时也没有可以被选为主键的唯一索引(上面的条件),这时候InnoDB会选择内置的ROWID作为主键,写入顺序和ROWID增长顺序一致;
  •  除此以外,如果一个InnoDB表又没有显示主键,又有可以被选择为主键的唯一索引,但该唯一索引可能不是递增关系时(例如字符串、UUID、多字段联合唯一索引的情况),该表的存取效率就会比较差。

该贴由hui.chen转至本版2014-11-5 15:57:34
该贴由hui.chen转至本版2014-11-5 15:58:12
该贴由hui.chen转至本版2014-11-5 16:14:39



赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论