MyBatis常见报错问题及解决方案

 更新时间:2020年11月17日 10:52:18   作者:龙谷情Sinoam  
这篇文章主要介绍了MyBatis常见报错问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这是一个出错的代码

public interface OrderInfoManageMapper {
  List<GetOrderInfoManageListReq> selectAllOrder();
  void modifyDelivery(int id);
  void removeOrder(int id);
  List<GetOrderInfoManageListReq> selectOrderById(@Param("id") Integer id);
}

一、报错:

1 There is no getter for property named 'id' in 'class java.lang.Integer'

检查mapper.xml文件,没错,如下:

<select id="selectOrderById" parameterType="java.lang.Integer" resultMap="BaseResultMap">
    SELECT DISTINCT
    order_info.id,
    user_info.user_name,
    order_info.order_status,
    order_info.pay_type,
    order_info.total_price,
    ship_address.ship_user_name,
    ship_address.ship_user_mobile,
    ship_address.ship_address,
    order_goods.goods_desc,
    order_goods.goods_sku,
    order_goods.goods_icon,
    order_goods.goods_price
    FROM
    order_info,
    user_info,
    ship_address,
    order_goods
    WHERE
    order_info.id = order_goods.order_id
    AND order_info.user_id = user_info.id
    AND order_info.ship_id = ship_address.id
    <if test="id!= null and id!= '' ">
      AND order_info.id = #{id}
    </if>
  </select>

检查mapper接口,如下:

public interface OrderInfoManageMapper {
  List<GetOrderInfoManageListReq> selectAllOrder();
  void modifyDelivery(int id);
  void removeOrder(int id);
  List<GetOrderInfoManageListReq> selectOrderById(Integer id);
}

看似没有问题,但是id的话,需要这么写(看最后一行):

public interface OrderInfoManageMapper {
  List<GetOrderInfoManageListReq> selectAllOrder();
  void modifyDelivery(int id);
  void removeOrder(int id);
  List<GetOrderInfoManageListReq> selectOrderById(@Param("id") Integer id);
}

二、sql没问题却报错:

java.sql.SQLException: 无效的列类型: 1111

原因是在mybatis中

 SELECT
 C_NAME1,
 C_NAME2
 FROM
 MY_TABLE
 WHERE 
 1=1
 AND ID IN ({#param})

param是java传来的字符串 'id1','id2','id3'

此时就会报这个错误,因为使用in条件时不能用#,要使用$,如

 SELECT
 C_NAME1,
 C_NAME2
 FROM
 MY_TABLE
 WHERE 
 1=1
 AND ID IN ({$param})

三、java想mybatis中传入‘a','b','c',放在in中

可能会这么写mybatis:

 SELECT * FROM TABLE_NAME
 WHERE 1=1
 <if para!= null && para!="" >
 AND PARS in (#{para})
 </if>

java传过来的para为

 String para = "'a','x','d','g'";

此时预期效果为

 SELECT * FROM TABLE_NAME
 WHERE 1=1
 AND PARS in ('a','x','d','g')

但是判断会通过,值不会传入,会出现:

 SELECT * FROM TABLE_NAME
 WHERE 1=1
 AND PARS in ()

将#换成$才可以。虽然#很安全

SELECT * FROM TABLE_NAME
WHERE 1=1
<if para!=null && para!="" >
AND PARS in (${para})
</if>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java8 Stream API 详细使用方法与操作技巧指南

    Java8 Stream API 详细使用方法与操作技巧指南

    这篇文章主要介绍了Java8 Stream API 详细使用方法与操作技巧,总结分析了Java8 Stream API 基本功能、使用方法与操作注意事项,需要的朋友可以参考下
    2020-05-05
  • log4j2的异步使用及添加自定义参数方式

    log4j2的异步使用及添加自定义参数方式

    这篇文章主要介绍了log4j2的异步使用及添加自定义参数方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • springboot项目中实现访问druid内置监控页面

    springboot项目中实现访问druid内置监控页面

    这篇文章主要介绍了springboot项目中实现访问druid内置监控页面的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java多线程与线程池技术分享

    Java多线程与线程池技术分享

    这篇文章主要介绍了Java多线程与线程池技术分享,线程池本质是池化技术的应用,和连接池类似,创建连接与关闭连接属于耗时操作,下文相关介绍需要的小伙伴可以参考一下
    2022-03-03
  • JVM之内存分配和回收机制

    JVM之内存分配和回收机制

    本篇主要介绍JVM内存分配和回收策略,内容主要节选自《深入理解java虚拟机》,需要的朋友可以参考下
    2023-05-05
  • Maven默认中央仓库(settings.xml 配置详解)

    Maven默认中央仓库(settings.xml 配置详解)

    这篇文章主要介绍了Maven默认中央仓库(settings.xml 配置详解),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12
  • mybatisplus逻辑删除基本实现和坑点解决

    mybatisplus逻辑删除基本实现和坑点解决

    这篇文章主要介绍了mybatisplus逻辑删除基本实现和坑点解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • springboot+rabbitmq实现指定消费者才能消费的方法

    springboot+rabbitmq实现指定消费者才能消费的方法

    当项目部署到测试环境后,QA测试过程中,总是“莫名其妙”的发现所保存的用户付款单数据有问题。这篇文章主要介绍了springboot+rabbitmq实现指定消费者才能消费,需要的朋友可以参考下
    2021-11-11
  • Java的NIO与IO的详解及对比

    Java的NIO与IO的详解及对比

    这篇文章主要介绍了Java的NIO与IO的详解及对比的相关资料,需要的朋友可以参考下
    2017-03-03
  • druid升级后sql监控页面为空白的解决

    druid升级后sql监控页面为空白的解决

    这篇文章主要介绍了druid升级后sql监控页面为空白的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06

最新评论