Mybatis获取自增主键并发问题,Jdbc3KeyGenerator
已知:
在数据库表自增的情况下,mybatis执行完一条insert sql后,Jdbc3KeyGenerator获取主键的逻辑,是在insert语句后获取最大的id。
场景:
线程A:插入insert语句先执行,然后执行Jdbc3KeyGenerator获取最大的id。
那么在线程A的Jdbc3KeyGenerator获取最大id前一时刻,线程B:又有insert语句执行了。
问:
那线程A获取到的id是线程B执行insert后的id,还是线程A执行insert的id。
mybatis
数据库
mysql
赞
收藏 0
回答 1
待解决
相关问题
并发问题和内存数据刷盘问题
2907浏览 • 1回复 待解决
MySQL 非自增的字符串主键会加间隙锁吗?
3302浏览 • 1回复 待解决
JSUI中TouchMove连续触发问题
2214浏览 • 1回复 待解决
sharding-jdbc分库分表的问题
991浏览 • 1回复 待解决
生态规则管控场景中获取自身场景值为空
828浏览 • 1回复 待解决
数据库主键字段的问题有知道的吗?
1636浏览 • 1回复 待解决
聊一聊DS的低代码开发问题
5128浏览 • 1回复 待解决
关于服务卡的界面开发问题有知道的吗?
1674浏览 • 1回复 待解决
这句sql会导致并发出问题吗 ?
1218浏览 • 1回复 待解决
mysql 自增字段如何重设?
1589浏览 • 1回复 待解决
使用mysql命令行insert时,如何直接获取到自增id
2494浏览 • 1回复 待解决
PHP高并发写入数据重复问题有知道的吗?
1224浏览 • 1回复 待解决
watch3如何获取海拔高度?
1564浏览 • 1回复 待解决
同一条 sql 在 navicate 中执行很快,用 mybatis 执行时约 3s有知道的吗?
3236浏览 • 1回复 待解决
关于node和mysql并发处理的小问题有知道的吗?
1138浏览 • 1回复 待解决
鸿蒙系统3无法获取系统定位信息怎么回事?
3368浏览 • 1回复 待解决
mybatis 多个参数时,如何用in?
1165浏览 • 1回复 待解决
明明有主键索引,为什么mysql索引失效?
2576浏览 • 1回复 待解决
loadData加载h5字符串,如何解决onUrlLoadIntercept不触发问题?
469浏览 • 1回复 待解决
对于ob3.1.3使用哪个jdbc驱动版本好呢?
2714浏览 • 1回复 待解决
为什么select 主键 from tb 就会自动走索引
1563浏览 • 1回复 待解决
openHarmony使用mediaLibrary模块获取缩略图失败,返回error3
3773浏览 • 1回复 待解决
怎样使用Mybatis处理PostgreSQL的jsonb类型的数据?
3954浏览 • 1回复 待解决
下面的数据库操作应该是有并发安全问题的吧?
1284浏览 • 1回复 待解决
PolarDB可以支持多少并发数?
1506浏览 • 1回复 待解决
不说数据库的情况下,就默认你是mysql吧,对于获取自增id的场景,mysql是插入完以后执行select LAST_INSERT_ID()就能获取到最大id(oracle在插入前,这点不同),mybatis做的也就是这样了,至于获取具体的数值,那是数据库对于这个的处理,特意试了下,开启事务以后,A事务先插入,但是不查询LAST_INSERT_ID(),B事务一次操作完,在B事务不管是否提交,A执行select LAST_INSERT_ID都是获取自己插入后的id,并没有串到B的id