mysql 选择两列做主键,组合主键VS. MySQL中的二级密钥

我有一个包含两个特定列的表,一个是自动递增的数字,另一个是自定义数字.这两列将在where条件中频繁获取.现在我有2个InnoDB引擎的选择:

>使用自动递增的数字作为主键,同时在自定义数字列上创建索引.这个选择将很快插入,因为新记录将逐个插入,但它会导致聚集索引上的某些合并或拆分.但是,在自定义数字列上构建索引需要额外的时间和空间.

>我可以将自动递增的数字和自定义数字列一起用作主键.在插入时,记录不会一个接一个地放置,因此它将导致频繁的B Tree主索引拆分和合并.

这两个选项将加速使用自动递增数字的查询和自定义数字列作为过滤条件.但是如果我们考虑插入和空间,哪一个会优先考虑?

非常感谢!

解决方法:

在这种情况下,复合主键似乎更好,因为密钥成为覆盖索引.为什么你认为它需要拆分?自动增量字段必须是InnoDB中复合主键中的第一个,即所有新行都将附加到末尾.

InnoDB中的自动增量字段在表中是唯一的,即使在复合主键中也是如此,而MyIsam中的字段在主键的每个新休息部分重新启动时都是如此.

标签:mysql,indexing,innodb

来源: https://codeday.me/bug/20190630/1336217.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值