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

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 封装的 matplotlib animation 不显示图像
  • ¥15 python摄像头画面无法显示
  • ¥15 关于#3d#的问题:d标定算法(语言-python)
  • ¥15 cve,cnnvd漏洞扫描工具推荐
  • ¥15 图像超分real-esrgan网络自己训练模型遇到问题
  • ¥15 如何构建全国统一的物流管理平台?
  • ¥100 ijkplayer使用AndroidStudio/CMake编译,如何支持 rtsp 直播流?
  • ¥15 用js遍历数据并对非空元素添加css样式
  • ¥15 使用autodl云训练,希望有直接运行的代码(关键词-数据集)
  • ¥50 python写segy数据出错