springboot mybatis常见异常及处理方法
1.in导致的异常
Data truncation: Truncated incorrect DOUBLE value:
异常过程:
mapper接口如下:
public int updateBatchId(@Param("batchId")String batchId,@Param("idStr")String idStr);
xml中sql如下:
<update id="updateBatchId" parameterType="java.lang.String">
update pdm_description_error_msg set batch_id = #{batchId},status = "1",process_num = process_num +1
where id in (#{idStr})
</update>
原因分析:
mybatis中in不能这样写,需要使用foreach,不然就会报如上的错误。
解决办法:(这里的idStr是以逗号分隔的,形式是这样的:1,2,3,4)
<update id="updateBatchId" parameterType="java.lang.String">
update pdm_description_error_msg set batch_id = #{batchId},status = "1",process_num = process_num +1
where id in
<foreach item="item" index="index" collection="idStr.split(',')" open="(" separator="," close=")">
'${item}'
</foreach>
</update>
异常总结
之前写sql时是使用注解的方式写的,通过那种方式,在java代码中是可以直接使用以逗号分隔的字符串的,例子如下:
public String updateBatchId(String batchId,String idStr){
StringBuilder stringBuilder = new StringBuilder();
stringBuilder.append("update pdm_error_msg set batch_id = '" + batchId + "',status=1,process_num=process_num+1 where " +
" (status=0 or status = 3) and id in ("+idStr+")");
return stringBuilder.toString();
}
这个是在java中直接拼接的sql可以,可以直接使用带逗号的字符串,在xml不行。
2.group_concat
这个mysql中关键字其实一般是不会使用的,但是有时使用group by做分组的时候,又希望把分组的结果拿出来,就可能会使用这个关键字,但是,重点是这个但是,如果返回的字段的长度过长,就会直接截断,然后也不抛异常,然后返回出来的结果就是一个阶段后的结果。
为啥要截断呢?
mysql为了优化性能
那多长会截断呢?
默认就是1024个字节,这才多长啊。
能不能避免不被截断?
可以,不过需要mysql的权限,让dba设置,不过dba爸爸估计不会帮这个忙
总结
严格来说这个锅不是mybatis的锅,其实是mysql为了优化性能搞的,举个例子,如果你程序开发测试环境随便造的数据,都很短,没问题,当部署到生产环境,运行一段时间,出问题,那估计问题就很严重。
3.is not null 和 != ; is null 和 =
这个在平时写sql的时候一般没什么问题,遇见null值判断,都会使用is,或者is not,但是偶尔会写成!=,这就搞飞机了,写成这样sql也不会抛异常,但是就是统计的数据不准确。原因就是null值不能使用 =,!=,<>等判断。
4.provider中sql语句把反斜线去掉,导致的转义问题
更新于--------------------------------------2020-01-15---------------------------------------
springboot中使用mybatis,现在很多小伙伴都不使用xml的方式写sql了,而是通过provider,如果牵涉到批量操作,基本上大家都不会直接在mapper中写sql,而是在provider中通过字符串拼接的方式来实现sql,这个写一般的sql没什么问题,一旦遇见一些坑爹的场景其实还是xml的方式比较好,比如下面说的问题:
场景:把表A中的message字段批量读出来,一次读取100条,批量插入到表B,实现方式是在provider中实现字符串拼接
代码如下:
public String insertCheckMsgBatch(List<CheckMsg> msgList) {
StringBuffer sql = new StringBuffer();
sql.append("insert into table(message,status) values "); if(!CollectionUtils.isEmpty(msgList)) {
int i = 0;
for(CheckMsg msg : msgList) {
i++;
sql.append("("+msg.getMessage()+","+msg.getStatus()); if(i < msgList.size()) {
sql.append("),");
} else {
sql.append(")");
}
}
} return sql.toString();
}
出现的问题: 由于表A中的message带有转义字符,会把字符串中的单引号和双引号转义,但是被上面一搞,所有的转义字符都没了,比如 "\"abc\'" 经过这玩意一搞变成了 ""abc'",但是这个也可以正常插入数据库,但是下次读出来就会出问题,因为这是一个异常的字符串。
解决办法:
上面问题的根源在于通过provider没有经过PreparedStatement预编译,如果经过这个预编译mybatis其实是可以处理这些特殊的字符的,ok,那就想办法让mybatis预编译,有两种方法,一种是改成xml方式,这种还要改,麻烦,另一个种是直接通过在mapper文件中写批处理sql的方式,这种实际和在xml一样。如下:
@Insert({"<script>" +
"insert into table(message,status) values " +
"<foreach item='item' index='index' collection='msgList' separator=','> " +
"(#{item.message},#{item.status})" +
"</foreach>" +
"</script>"})
public int insertMsgBatch(@Param("msgList") List<Msg> msgList);
这样就可以解决问题了,记录一下
springboot mybatis常见异常及处理方法的更多相关文章
- Maven常见异常及解决方法(本篇停更至16-4-12)
本篇文章记录了老猫在学习整合Maven和SSH过程中遇到的问题,有的问题可以解决.有的问题还不能解决. 方法不一定适合全部的环境.但绝对是本人常遇到的常见异常.在这里做一个笔记和记录,也分享给大家,希 ...
- Maven常见异常及解决方法
异常1: [ERROR] Failed to execute goal on project biz_zhuhai: Could not resolve dependencies for projec ...
- maven常见异常以及解决方法
本文写的是我在整合ssm框架时遇到的一些问题,我估计很多人也会遇到,所以,这里作为一个总结,希望能够帮助大家解决问题 一,加入shiro组件时抛出的异常 加入步骤(略) 问题 1,保存后,无法导入sh ...
- python常见异常及解决方法
异常1: ValueError: unsupported hash type sha224 ERROR:root:code for hash sha256 was not found. Traceba ...
- WebServices CXF开发常见异常及解决方法
2011-7-14 10:10:59 org.apache.cxf.service.factory.ReflectionServiceFactoryBean buildServiceFromClass ...
- Maven常见异常及解决方法---测试代码编译错误
[ERROR] Please refer to E:\maven\web_nanchang\target\surefire-reports for the individual test result ...
- WebDriver(Selenium2) 常见异常及处理方法
http://uniquepig.iteye.com/blog/1568197 Exception NoSuchElementException Solutions 1. Check the l ...
- SpringBoot + MyBatis(注解版),常用的SQL方法
一.新建项目及配置 1.1 新建一个SpringBoot项目,并在pom.xml下加入以下代码 <dependency> <groupId>org.mybatis.spring ...
- Spring10种常见异常解决方法
在程序员生涯当中,提到最多的应该就是SSH三大框架了.作为第一大框架的Spring框架,我们经常使用. 然而在使用过程中,遇到过很多的常见异常,我在这里总结一下,大家共勉. 一.找不到配置文件的异常 ...
随机推荐
- 在Visual Studio 2019中开启预览功能
在Visual Studio 2019 菜单 [工具] > [选项] > [环境] 下的预览功能页面焕然一新!我们介绍了预览功能页面,以便您可以轻松找到这些功能并能够控制其启用.新布局提供 ...
- C 输入和输出、char类型
参考链接:https://www.runoob.com/cprogramming/c-input-output.html 标准输入输出头文件stdio.h #include是一个预处理指令,用于引入s ...
- 开发技术--Python核心知识A
开发|Python核心知识A A篇,主要介绍Python基础中列表,元祖,字典,集合,字符串,I/O,条件与循环,异常处理的底层知识与使用的注意事项. 希望大家对于Python会有新的收获,本篇不同于 ...
- gsoap生成webservice调用客户端接口
1.下载gsoap2.8 2.运行 wsdl2h.exe -o XXX.h XXX.wsdl wsdl文件可以是本地文件,也可以是服务器的wsdl,比如http://192.168.0.122:333 ...
- sublime_text运行python ctrl+b运行的界面隐藏了怎么重新调出来恢复显示?
sublime_text运行python ctrl+b运行的界面隐藏了怎么重新调出来恢复显示?搜索了下都是说怎么隐藏的,隐藏后怎么恢复显示的没找到看进程还在运行,但调不出来看运行结果了,console ...
- 解决eclipse中maven多模块项目显示不全的问题
背景:在eclipse中导入maven项目,后来发现有的子模块不能正常的显示出现 原因:没有加载到子模块的pom文件 解决方法:重新导入:import-> 勾选项目->选择你缺少的项目的p ...
- C++学习03_引用
基本使用 C++提供了给变量命名的机制,就是引用(Reference).引用是一种复合类型. //语法 数据类型 &name=data 注意,引用在定义时需要添加&,在使用时不能添加& ...
- CentOS 8 网卡命令
nmcli n 查看nmcli状态 nmcli n on 启动nmcli nmcli c up eth0 启动网卡eth0 nmcli c down eth0 关闭网卡eth0 nmcli d c ...
- centos7编译安装php 遇到的问题
centos7 编辑安装php遇到的问题: ./configure 配置遇到的No package 'libxml-2.0' found缺失libxml2.0 库,解决方法: yum -y insta ...
- django settings实现原理及自定义项目settings配置
基于django 中的settings实现原理,实现自己项目配置文件的可插拔式设计 ##首先说一下django中settings.py中的实现原理 ''' 应该明确一点,django暴露给用户一个自定 ...