首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 主键语句_MySQL 主键

主键有两个性质需要考虑: 单调性 每次插入一条数据,其 ID 都是比上一条插入的数据的 ID 大,就算上一条数据被删除。...主键的单调性 为何会有单调性的问题? 这主要跟主键最大值的获取方式,以及存放位置有关系。 如果最大值是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删除而减小。...主键最大值怎么取的?存放到哪里?...保证事务 A 的数据的 ID 连续: innodb_autoinc_lock_mode = 1 (AUTO-INC Locking) 和上面的区别在于,当执行 确定数量 的批量插入时,使用轻量级互斥量(...其他 如果主动指定 ID 为 0 或者 NULL 插入,则会使用数据库生成的 ID。

10.8K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql主键策略_MySQL 主键机制

    主键:特指在增列上定义的主键。 主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 增值保存在哪? 不同的存储引擎保存增值的策略不一样; a....每次重启后第一次打开表,都会去查找增值的最大值max(id), 并设置表当前增值为max(id) + 1; mysql8.0, 增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的值...锁的优化 a. 锁不是事务锁,在每次申请完就释放;在5.0版本会在语句执行完才释放,后续版本无须在语句执行完才释放;支持批量申请; b....:语句执行过程中,第一次申请 id,会分配 1 个;1 个用完以后,这个语句第二次申请 id,会分配 2 个;2 个用完以后,还是这个语句,第三次申请 id,会分配 4 个;依此类推,同一个语句去申请...id,每次申请到的 id 个数都是上一次的两倍。

    9.5K50

    【说站】java减运算符有哪些?

    java减运算符有哪些? 说明 1、自我增加(++)自我减少(-)运算符是一种特殊的算术运算符,它需要两个操作数来运算,而自我增加自我减少运算符是一个操作数。...2、前缀减法(++a,-a):进行减操作,然后进行表达式操作。 3、后缀减法(a++,a-):先进行表达式操作,再进行减操作。...String[] args) {     int a = 5;//定义一个变量;     int b = 5;     int x = 2 * ++a;     int y = 2 * b++;     //运算符前缀运算后...a=6,x=12     System.out.println("运算符前缀运算后a=" + a + ",x=" + x);     //运算符后缀运算后b=6,y=10     System.out.println...("运算符后缀运算后b=" + b + ",y=" + y); } 以上就是java减运算符的介绍,希望对大家有所帮助。

    88330

    Java减运算符神坑笔试题

    count = count++; } System.out.println("count = "+count);     答:count = 0 首先count++是一个有返回值的表达式,返回值是count加前面的值...,java加处理的流程是先把count的值(不是引用),拷贝到一个临时变量区,然后对count变量加1,接着返回临时变量区的值。...所以上面代码中第一次循环执行的步骤是JVM把count的值(0)拷贝到临时变量区,然后count值加1,这时count的值是1,接着返回临时变量区的值(值还是0),最后赋值给count,此时count值被重置成...所以上面代码语句,count = count++可以按照如下代码来理解: int autoAdd(int count) {     int temp = count;     count = coutn + 1;...不过这个问题在不同的语言环境中是不一样的,在c++中count = count++与count++是等效的,但在Java中是不等效的。

    1.7K30

    【面试题精讲】Java减运算符

    1. 什么是减运算符? 减运算符是一种用于对变量进行加 1 或减 1 操作的特殊运算符。在大多数编程语言中,运算符表示将变量的值增加 1,而减运算符表示将变量的值减少 1。...在 Java 中,减运算符有两种形式: 前缀形式:++i 或 --i 后缀形式:i++ 或 i-- 其中,前缀形式会先执行减操作,然后返回结果...以 Java 为例,当使用减运算符时,编译器会生成相应的字节码指令来执行操作。...对于前缀形式的减运算符,编译器会先将变量的值加 1 或减 1,然后再返回结果;对于后缀形式的减运算符,编译器会先返回原始值,然后再将变量的值加 1 或减 1。 4....减运算符的使用示例 下面是 Java减运算符的使用示例: int i = 0; System.out.println(++i); // 输出: 1 System.out.println(

    29730

    浅谈MySQL

    =2; set session auto_increment_offset=1; 生成奇数的 auto_increment_offset表示起始数字 auto_increment_increment...如果存在字段,MySQL会维护一个锁,和锁相关的一个参数为(5.1.22版本之后加入) innodb_autoinc_lock_mode:可以设定3个值,0,1,2 0:traditonal...六、的过程 第一种,插入空值的时候 当innodb_autoinc_lock_mode=0时 1、申请AUTO_INC锁 2、得到当前的AUTO_INCREMENT值n,并加1 3、执行插入操作...第二种,插入已经有值的 1、插入第一条数据 2、如果失败流程结束 3、如果成功,申请AUTO_INC锁 4、调用set_max函数,修改AUTO_INCREMENT 5、语句结束,释放AUTO_INC...为了保证主库和从库的ID的一致性,binlog中会有set insert_ID命令,标明这个load语句的第一行的ID值,这样在表锁的情况下,就可以保证一致性了。

    5K30
    领券