Mybatis 批量插入数据 关于Oracle 批量插入报错:ORA-00933: SQL 命令未正确结束
问题:用mybaits 批量插入数据到Oracle 数据库的时候,
报错:ORA-00933: SQL 命令未正确结束 / ORA-00933: SQL command not properly ended ;意思就是 语法错误
原因:
oracle 批量插入与mysql 的批量插入的方式是不同的,
insert into tablename()values(),(),(); ---这个是mysql 的批量插入形式
insert all into tablename() values() into tablename() values() -------这个是Oracle批量插入形式
下面是 Mybaits:oracle数据库批量插入数据的样式:
//方式1: <insert id="insertclobtest2" parameterType="com.inspur.tax.sjaqgl.sjflfjgl.data.ClobEntity"> INSERT ALL <foreach collection="list" item="item" index="index"> INTO ainsertclob (id, blobtest) VALUES (#{item.id}, #{item.blobtest}) </foreach> select 1 from dual </insert> //方式2: <insert id="insertclobtest3" parameterType="com.inspur.tax.sjaqgl.sjflfjgl.data.ClobEntity"> INSERT INTO ainsertclob (id, blobtest) <foreach collection="list" item="item" index="index" separator="union all"> SELECT #{item.id} ,#{item.blobtest} from dual </foreach> </insert> // 方式3: <insert id="addBatch" parameterType="java.util.List"> BEGIN <foreach collection="list" item="item" index="index" separator=""> insert into blacklist (id, userid, deviceid, createdate, updatedate, "LEVEL") VALUES ( USER_INFO_SEQ.NEXTVAL,#{item.userId,jdbcType=INTEGER},#{item.deviceId,jdbcType=VARCHAR}, #{item.createDate,jdbcType=DATE},sysdate, #{item.level,jdbcType=INTEGER} ); </foreach> COMMIT; END; </insert>
下面是Mybaits: mysql 数据库批量插入数据的例子:
<insert id="insertclobtest1" parameterType="com.inspur.tax.sjaqgl.sjflfjgl.data.ClobEntity"> INSERT INTO ainsertclob (id, blobtest) VALUES <foreach collection="list" item="item" separator=","> (#{item.id}, #{item.blobtest}) </foreach> </insert>
Mybatis,oracle,ORA-00933: SQL 命令未正确结束
原因是:批量插入时,如果没有主键,一定要显式指定useGeneratedKeys为false,否则会报: SQL 命令未正确结束
<insert id="insert_" useGeneratedKeys="false"> </insert>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架