如何在mybatis中向BLOB字段批量插入数据

 更新时间:2020年10月22日 11:28:43   作者:追枫狼  
这篇文章主要介绍了如何在mybatis中向BLOB字段批量插入数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

  最近接手一个需求,需要用xxl-job定时任务同步三方库中新增的数据,粗略一看挺得意,以为一两小时就搞定了,但事与愿违,编码两小时却被一个BLOB字段玩了一下午。

  每次获取50条数据过来,每条数据中有一个字段是BLOB类型的图片,需求也要将图片放入数据库(个人不建议这么玩,生产上千万的数据会造成数据库很臃肿,建议放到ftp或者minio上比较好),字段中的图片过来时已经被转换成了base64的格式,在往数据库批量插入时,数据库BLOB字段对应的实体使用byte[],程序执行时报了如下错误: 

org.springframework.jdbc.UncategorizedSQLException:
### Error updating database.  Cause: java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
### The error may exist in file [D:\ZtlandCode\AreaCodeVersion\WX\land-core-wx\land-core-common\target\classes\mapper\DjSfzbMapper.xml]
### The error may involve com.ztland.core.common.mapper.DjSfzbMapper.savaSfzBatch-Inline
### The error occurred while setting parameters
### SQL: INSERT INTO DJ_SFZB (ID, SFZXM, SFZZH, SFZXBMC, SFZMZ, SFZSR, SFZDZ, SFZQPDW, SFZYXQ, SFZTP, SFYX, CJSJ, ZHXGSJ) SELECT DJ_SFZB_ID.nextval AS ID, A.* FROM <br>(SELECT ? AS SFZXM, ? AS SFZZH, ? AS SFZXBMC, ? AS SFZMZ, ? AS SFZSR, ? AS SFZDZ, ? AS SFZQPDW, ? AS SFZYXQ, ? AS SFZTP, '1' AS SFYX, sysdate AS CJSJ, sysdate AS ZHXGSJ FROM dual) A
### Cause: java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值;

uncategorized SQLException; SQL state [72000]; error code [1461]; ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值;

nested exception is java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值

  原因是oracle中保存大长度字段时,长度介于2000-4000之间的字段会先转换为LONG类型,报错时的SQL如下:

INSERT INTO DJ_SFZB
(
ID,SFZXM,SFZZH,SFZXBMC,SFZMZ,SFZSR,SFZDZ,SFZQPDW,SFZYXQ,SFZTP,
SFYX,CJSJ,ZHXGSJ
)
select DJ_SFZB_ID.NEXTVAL as ID,A.* from (
<foreach collection ="list" item="item" index= "index" separator =" union all ">
 select
 #{item.sfzxm} as SFZXM,#{item.sfzzh} as SFZZH,
 #{item.sfzxbmc} as SFZXBMC,#{item.sfzmz} as SFZMZ,#{item.sfzsr} as SFZSR,
 #{item.sfzdz} as SFZDZ,#{item.sfzqpdw} as SFZQPDW,#{item.sfzyxq} as SFZYXQ,
 #{item.sfztp,jdbcType=BLOB} as SFZTP,'1' as SFYX,sysdate as CJSJ,sysdate as ZHXGSJ
 from dual
</foreach >
) A

  问题排查发现:批量就byte[]保存到BLOB字段时,不能使用Union all,不能使用from dual虚表查询获取数据的方式,因为字段长度介于2000-4000之间时,oracle会将字段类型转为long类型

  解决方法:使用”begin...;end;“的方式,修改后的SQL如下:

begin
<foreach collection ="list" item="item" index= "index" separator =";">
 INSERT INTO DJ_SFZB
 (
 ID,SFZXM,SFZZH,SFZXBMC,SFZMZ,SFZSR,SFZDZ,SFZQPDW,SFZYXQ,SFZTP,
 SFYX,CJSJ,ZHXGSJ
 ) values (
 #{item.id,jdbcType=NUMERIC},
 #{item.sfzxm,jdbcType=VARCHAR},#{item.sfzzh,jdbcType=VARCHAR},
 #{item.sfzxbmc,jdbcType=VARCHAR},#{item.sfzmz,jdbcType=VARCHAR},#{item.sfzsr,jdbcType=VARCHAR},
 #{item.sfzdz,jdbcType=VARCHAR},#{item.sfzqpdw,jdbcType=VARCHAR},#{item.sfzyxq,jdbcType=VARCHAR},
 #{item.sfztp,jdbcType=BLOB},'1',sysdate,sysdate
 )
</foreach >
;end;

  问题得以解决。

到此这篇关于如何在mybatis中向BLOB字段批量插入数据的文章就介绍到这了,更多相关mybatis批量插入数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring Boot详解创建和运行基础流程

    Spring Boot详解创建和运行基础流程

    这篇文章主要介绍了SpringBoot创建和运行的基础流程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • java中Collections.sort排序函数用法详解

    java中Collections.sort排序函数用法详解

    本篇文章主要介绍了java中Collections.sort排序函数用法详解,非常具有实用价值,需要的朋友可以参考下。
    2016-12-12
  • 用java代码帮朋友P图

    用java代码帮朋友P图

    这篇文章主要为大家介绍了使用java代码帮朋友P图的实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • spring集成redis cluster详解

    spring集成redis cluster详解

    这篇文章主要介绍了spring集成redis cluster详解,分享了maven依赖,Spring配置,增加connect-redis.properties 配置文件等相关内容,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • java直接插入排序示例

    java直接插入排序示例

    这篇文章主要介绍了java直接插入排序示例,插入排序的比较次数仍然是n的平方,但在一般情况下,它要比冒泡排序快一倍,比选择排序还要快一点。它常常被用在复杂排序算法的最后阶段,比如快速排序。
    2014-05-05
  • SpringBoot 项目打成 jar后加载外部配置文件的操作方法

    SpringBoot 项目打成 jar后加载外部配置文件的操作方法

    这篇文章主要介绍了SpringBoot 项目打成 jar后加载外部配置文件的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • Java实现分页代码

    Java实现分页代码

    这篇文章主要为大家详细介绍了Java实现分页代码,提高查询效率,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • Java面试之如何实现10亿数据判重

    Java面试之如何实现10亿数据判重

    当数据量比较大时,使用常规的方式来判重就不行了,所以这篇文章小编主要来和大家介绍一下Java实现10亿数据判重的相关方法,希望对大家有所帮助
    2024-02-02
  • Java中Semaphore信号量的方法解析

    Java中Semaphore信号量的方法解析

    这篇文章主要介绍了Java中Semaphore信号量的方法解析,  Semaphore信号量是用来控制同 时访问 特定 资 源的 线 程数量,它通 过协调 各个 线 程,以保证合理的使用公共 资源,需要的朋友可以参考下
    2023-12-12
  • 教你用JDK编译Java文件的方法

    教你用JDK编译Java文件的方法

    这篇文章主要介绍了教你用JDK编译Java文件的方法,分步骤给大家介绍了设置环境变量的方法,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2022-01-01

最新评论