《MYSQL教程Mysql 主键自增长auto_increment问题分析》要点:
本文介绍了MYSQL教程Mysql 主键自增长auto_increment问题分析,希望对您有用。如果有疑问,可以联系我们。
本节内容:
Mysql 主键自增长MYSQL教程
在mysql数据库中,主键由auto_increment实现自增长,若自定义函数来表示auto_increment的话可以如下:
MYSQL教程
但是,此办法会有并发方面的问题,如两个事务中就可能获取到同一个id而其中一个失败,所以需要锁表:
MYSQL教程
以上办法,可以实现一些复杂的自增长逻辑要求,比如在一个复合主键中,要求以其中一个主键为参照物,另一个主键重新从1开始自增长,但缺点是需要锁表,在大并发环境中会影响一定的效率,在mysql 5.1.22版本之前,均是需要锁表的,但在5.1.22版本之后,引入了一种新的办法来解决自增长的效率问题:
MYSQL教程
说明:
在级别1中,引入了一个轻量级的互斥量,在不同的事务中auto_increment总是可以获取到最新的自增长主键值而不需要锁表.
但对于无法提前获知插入行数的sql依然需要锁表,如insert...select... replace...select... load data 还是使用表锁.MYSQL教程
有关Mysql 主键自增长的问题,就介绍这些了,希望对大家有所赞助.MYSQL教程
欢迎参与《MYSQL教程Mysql 主键自增长auto_increment问题分析》讨论,分享您的想法,维易PHP学院为您提供专业教程。