mysql主键自增长空缺_Mysql 主键自增长auto_increment问题分析

本节内容:

Mysql 主键自增长

在mysql数据库中,主键由auto_increment实现自增长,若自定义函数来表示auto_increment的话可以如下:

复制代码 代码示例:

create function select_autoincrement_id() returns int(11)

begin

select max(id)+1 from table_name;

end

但是,此方法会有并发方面的问题,如两个事务中就可能获取到同一个id而其中一个失败,所以需要锁表:

复制代码 代码示例:

create function select_autoincrement_id() returns int(11)

begin

select max(id)+1 from table_name for update;

end

以上方法,可以实现一些复杂的自增长逻辑要求,比如在一个复合主键中,要求以其中一个主键为参照物,另一个主键重新从1开始自增长,但缺点是需要锁表,在大并发环境中会影响一定的效率,在mysql 5.1.22版本之前,均是需要锁表的,但在5.1.22版本之后,引入了一种新的方法来解决自增长的效率问题:

innodb_autoinc_lock_mode = 0(全部使用表锁)

innodb_autoinc_lock_mode = 1(默认,可预判行数时使用新方式,不可时使用表锁)

innodb_autoinc_lock_mode = 2(全部使用新方式)

说明:

在级别1中,引入了一个轻量级的互斥量,在不同的事务中auto_increment总是可以获取到最新的自增长主键值而不需要锁表。

但对于无法提前获知插入行数的sql依然需要锁表,如insert...select... replace...select... load data 还是使用表锁。

有关Mysql 主键自增长的问题,就介绍这些了,希望对大家有所帮助。

>>> 您可能感兴趣的文章:

MySQL自增字段的设置方法分享

设置与修改Mysql 自增ID的起始值

mysql数据库自增id用法大全

深入解析mysql自增字段auto_commit

mysql为现有字段添加自增属性的例子

mysql获取自增ID的几种方法

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值