
尝试直接用 useGeneratedKeys,但公司的框架模版使用的 mybatis 依赖是 3.2.8 版本的,看了官网需要 3.3.1 才支持。如果在不修改 mybatis 依赖版本的情况下,除了插入后再查一次,如何能获取批量插入记录的主键呢?
1 micean 2021-01-10 14:53:49 +08:00 如果用 batch 肯定是没有的 用单次提交试试吧 或者开事务,批量插入后查一次 |
2 340244120w 2021-01-10 15:11:06 +08:00 via iPhone 自己生成主键 |
3 alexfarm OP @340244120w 自己生成就不能使用自增主键了啊,多节点还要处理唯一性啊 |
5 w292614191 2021-01-10 15:36:41 +08:00 selectkey |
6 alexfarm OP @w292614191 这个也不支持批量的 |
7 xiang0818 2021-01-10 21:30:31 +08:00 用分布式 Id 吧,事先生成主键会好点 |
8 Still4 2021-01-11 10:26:23 +08:00 升级版本,实在不想升级就参考支持的版本自己实现一遍,所以还是升级比较方便 |
9 shanghai1943 2021-01-11 10:29:31 +08:00 增加一个 uuid 字段,批量插入之后再根据 uuid 批量查询对应的自增 id |
10 slyang5 2021-01-11 13:00:02 +08:00 自己生成主键 ID 吧 set 一下 再批量插入 |
11 RedBeanIce 2021-01-11 13:39:34 +08:00 |
12 shanghai1943 2021-01-11 14:06:00 +08:00 额没看清题目。尴尬。 |
13 hiveex 2021-01-11 15:21:12 +08:00 他的 batch 源码里也是 for 循环去插入 你直接用 for 记下 id |
14 wg20080215 2021-01-11 16:39:55 +08:00 @RedBeanIce 没毛病呀。 #9 的方案可以的,把 snowflake 生成的 UUID 字段作为非主键字段,插入数据库后拿着 UUID 去查 自增 ID 也可以的。不管你几台服务器 snowflake 都无所谓嘛 |
15 340244120w 2021-01-11 17:30:32 +08:00 |