在mybatis-plus中关于@insert注解自定义批处理sql导致其雪花算法失效而无法自动生成id的解决方法

受到这位作者的启发 ===> 原文在点这里

为了自己实现批量插入,我在mapper层使用@insert注解写了一段自定义sql

java 复制代码
//自定义的批量插入方法
@Insert("<script>" +
   "insert into rpt_material_hour(id,sample_time,rounding_time,cur_month,machine_no,data_code,data_value,create_user,create_time,update_user,update_time) values" +
   "   <foreach collection='materialDataList' separator=',' item='item'>" +
   "        (#{item.id},#{item.simpleTime},#{item.roundingTime},#{item.curMonth},#{item.machineNo},#{item.dataCode},#{item.dataValue}," +
   "         #{item.createUser},#{item.createTime},#{item.updateUser},#{item.updateTime})" +
   "   </foreach>"+
   "</script>")
void insertBatch(@Param("materialDataList")List<MaterialData> materialDataList);

报错如下

说明mybatis-plus的雪花算法失效了

但是我的entity对象明明声明了主键的生成策略为雪花算法

后来我去掉mapper层方法里的@Param注解后就好了

【注】我这里的数据源使用的是sqlserver

相关推荐
高兴就好(石2 小时前
DB-GPT部署和试用
数据库·gpt
这孩子叫逆3 小时前
6. 什么是MySQL的事务?如何在Java中使用Connection接口管理事务?
数据库·mysql
Karoku0663 小时前
【网站架构部署与优化】web服务与http协议
linux·运维·服务器·数据库·http·架构
码农郁郁久居人下3 小时前
Redis的配置与优化
数据库·redis·缓存
MuseLss4 小时前
Mycat搭建分库分表
数据库·mycat
Hsu_kk5 小时前
Redis 主从复制配置教程
数据库·redis·缓存
DieSnowK5 小时前
[Redis][环境配置]详细讲解
数据库·redis·分布式·缓存·环境配置·新手向·详细讲解
程序猿小D5 小时前
第二百三十五节 JPA教程 - JPA Lob列示例
java·数据库·windows·oracle·jdk·jpa
Flerken1015 小时前
数据库语言、SQL语言、数据库系统提供的两种语言
数据库·sql·oracle
掘根5 小时前
【网络】高级IO——poll版本TCP服务器
网络·数据库·sql·网络协议·tcp/ip·mysql·网络安全