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常见异常及处理方法的更多相关文章

  1. Maven常见异常及解决方法(本篇停更至16-4-12)

    本篇文章记录了老猫在学习整合Maven和SSH过程中遇到的问题,有的问题可以解决.有的问题还不能解决. 方法不一定适合全部的环境.但绝对是本人常遇到的常见异常.在这里做一个笔记和记录,也分享给大家,希 ...

  2. Maven常见异常及解决方法

    异常1: [ERROR] Failed to execute goal on project biz_zhuhai: Could not resolve dependencies for projec ...

  3. maven常见异常以及解决方法

    本文写的是我在整合ssm框架时遇到的一些问题,我估计很多人也会遇到,所以,这里作为一个总结,希望能够帮助大家解决问题 一,加入shiro组件时抛出的异常 加入步骤(略) 问题 1,保存后,无法导入sh ...

  4. python常见异常及解决方法

    异常1: ValueError: unsupported hash type sha224 ERROR:root:code for hash sha256 was not found. Traceba ...

  5. WebServices CXF开发常见异常及解决方法

    2011-7-14 10:10:59 org.apache.cxf.service.factory.ReflectionServiceFactoryBean buildServiceFromClass ...

  6. Maven常见异常及解决方法---测试代码编译错误

    [ERROR] Please refer to E:\maven\web_nanchang\target\surefire-reports for the individual test result ...

  7. WebDriver(Selenium2) 常见异常及处理方法

    http://uniquepig.iteye.com/blog/1568197 Exception NoSuchElementException Solutions    1. Check the l ...

  8. SpringBoot + MyBatis(注解版),常用的SQL方法

    一.新建项目及配置 1.1 新建一个SpringBoot项目,并在pom.xml下加入以下代码 <dependency> <groupId>org.mybatis.spring ...

  9. Spring10种常见异常解决方法

    在程序员生涯当中,提到最多的应该就是SSH三大框架了.作为第一大框架的Spring框架,我们经常使用. 然而在使用过程中,遇到过很多的常见异常,我在这里总结一下,大家共勉. 一.找不到配置文件的异常 ...

随机推荐

  1. 在Visual Studio 2019中开启预览功能

    在Visual Studio 2019 菜单 [工具] > [选项] > [环境] 下的预览功能页面焕然一新!我们介绍了预览功能页面,以便您可以轻松找到这些功能并能够控制其启用.新布局提供 ...

  2. C 输入和输出、char类型

    参考链接:https://www.runoob.com/cprogramming/c-input-output.html 标准输入输出头文件stdio.h #include是一个预处理指令,用于引入s ...

  3. 开发技术--Python核心知识A

    开发|Python核心知识A A篇,主要介绍Python基础中列表,元祖,字典,集合,字符串,I/O,条件与循环,异常处理的底层知识与使用的注意事项. 希望大家对于Python会有新的收获,本篇不同于 ...

  4. gsoap生成webservice调用客户端接口

    1.下载gsoap2.8 2.运行 wsdl2h.exe -o XXX.h XXX.wsdl wsdl文件可以是本地文件,也可以是服务器的wsdl,比如http://192.168.0.122:333 ...

  5. sublime_text运行python ctrl+b运行的界面隐藏了怎么重新调出来恢复显示?

    sublime_text运行python ctrl+b运行的界面隐藏了怎么重新调出来恢复显示?搜索了下都是说怎么隐藏的,隐藏后怎么恢复显示的没找到看进程还在运行,但调不出来看运行结果了,console ...

  6. 解决eclipse中maven多模块项目显示不全的问题

    背景:在eclipse中导入maven项目,后来发现有的子模块不能正常的显示出现 原因:没有加载到子模块的pom文件 解决方法:重新导入:import-> 勾选项目->选择你缺少的项目的p ...

  7. C++学习03_引用

    基本使用 C++提供了给变量命名的机制,就是引用(Reference).引用是一种复合类型. //语法 数据类型 &name=data 注意,引用在定义时需要添加&,在使用时不能添加& ...

  8. CentOS 8 网卡命令

    nmcli n 查看nmcli状态 nmcli n on 启动nmcli nmcli c  up eth0 启动网卡eth0 nmcli c down eth0 关闭网卡eth0 nmcli d c ...

  9. centos7编译安装php 遇到的问题

    centos7 编辑安装php遇到的问题: ./configure 配置遇到的No package 'libxml-2.0' found缺失libxml2.0 库,解决方法: yum -y insta ...

  10. django settings实现原理及自定义项目settings配置

    基于django 中的settings实现原理,实现自己项目配置文件的可插拔式设计 ##首先说一下django中settings.py中的实现原理 ''' 应该明确一点,django暴露给用户一个自定 ...