LH2017 2022-03-07 14:57 采纳率: 100%
浏览 351
已结题

mybatis传参报错 java.sql.SQLException: 无效的列索引

<if test="qysSignStatus != null and qysSignStatus !=''">
    AND DLCFAI.STATUS_CODE = #{qysSignStatus,jdbcType=VARCHAR}
</if>

使用mybatis,在传参qysSignStatus时,报错 Caused by: java.sql.SQLException: 无效的列索引
更具体的错误信息如下:

org.apache.ibatis.type.TypeException: 
Could not set parameters for mapping: 
ParameterMapping{property='qysSignStatus', mode=IN, javaType=class java.lang.String, jdbcType=VARCHAR, 
numericScale=null, resultMapId='null', jdbcTypeName='null', expression='null'}. 

Cause: org.apache.ibatis.type.TypeException: 
Error setting non null for parameter #1 with JdbcType VARCHAR . 
Try setting a different JdbcType for this parameter or a different configuration property. 
Cause: java.sql.SQLException: 无效的列索引
<select id="selectContractSettles" resultMap="BaseResultMap" parameterType="dms.core.sale.dto.SaleContractSettle">

参数传递用的是POJO,qysSignStatus属性类型为String类型,在POJO中设置了该属性,且有get和set方法,没有拼写错误,传参时有值不为空,SQL在Navicat中赋上值后可以正常查询
百思不得其解,网上也没找到类似的问题,求帮忙解惑!

  • 写回答

4条回答 默认 最新

  • CSDN专家-sinJack 2022-03-07 15:10
    关注

    接口怎么写的。
    @Param()指定一下。

    method(@Param("sale") SaleContractSettle sale)
    
    <if test="sale.qysSignStatus != null and sale.qysSignStatus !=''">
        AND DLCFAI.STATUS_CODE = #{sale.qysSignStatus,jdbcType=VARCHAR}
    </if>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月22日
  • 已采纳回答 3月14日
  • 创建了问题 3月7日

悬赏问题

  • ¥15 Qt4代码实现下面的界面
  • ¥15 prism提示我reinstall prism 如何解决
  • ¥15 asp.core 权限控制怎么做,需要控制到每个方法
  • ¥20 while循环中OLED显示中断中的数据不正确
  • ¥15 这个视频里的stm32f4代码是怎么写的
  • ¥15 JNA调用DLL报堆栈溢出错误(0xC00000FD)
  • ¥15 请教SGeMs软件的使用
  • ¥15 自己用vb.net编写了一个dll文件,如何只给授权的用户使用这个dll文件进行打包编译,未授权用户不能进行打包编译操作?
  • ¥50 深度学习运行代码直接中断
  • ¥20 需要完整的共散射点成像代码