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框架,我们经常使用. 然而在使用过程中,遇到过很多的常见异常,我在这里总结一下,大家共勉. 一.找不到配置文件的异常 ...
随机推荐
- Linux学习笔记之scp远程拷贝文件
0x00 拷贝本机/home/administrator/test整个目录至远程主机192.168.1.100的/root目录下 代码如下: scp -r /home/administrator/te ...
- 基本认证(Basic Authorization)
---------------------------------- import arcpy from base64 import encodestring username = 'xxx' pas ...
- 前端开发JS——引用类型
10.流程控制语句 注:var obj = {}:这里的obj转换boolean语句为true if语句和java是一样的,判断条件也是根据上篇博客提到的假性值 // 弹出一个带输入框的 ...
- MySQL之--修改密码
1.在Mac上安装MySQL会随机生成一个临时密码,如下: --24T02::.004376Z [Note] A temporary password is generated for root@lo ...
- ssh关闭服务关闭 nohup
默认输出 # nohup cmd & 指定输出路径 # nohup cmd > mylog.out 2>&1 &
- ANDROID培训准备资料之项目结构简单介绍
Android Studio项目结构初步主要介绍下面几个文件夹,后续再补充 (1)java文件夹的介绍 (2)Res文件夹的介绍 (3)R文件的介绍 (4)Manifests文件夹的介绍 我们先看看整 ...
- 019.nexus搭建docker镜像仓库/maven仓库
一.安装docker CE 参考docker doc https://docs.docker.com/install/linux/docker-ce/centos/ 二.docker启动nexus3 ...
- Vue+ElementUI 安装与应用
1.初始化创建一个vue项目: 打开终端输入命令 vue init webpack vueui ---------------------------------- ? Project name my ...
- odoo10学习笔记四:onchange、唯一性约束
转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/11189273.html 一:onchange机制[onchange=前端js函数!可以实现前端实时更新以及修 ...
- pyhive client连接hive报错处理:Could not start SASL
本来一切就绪,镜像里已安装如下主要的pip包. pyhive configparser pandas hdfs thrift sqlparse sasl thrift-sasl 但,使用pyhive ...