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中赋上值后可以正常查询
百思不得其解,网上也没找到类似的问题,求帮忙解惑!

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

method(@Param("sale") SaleContractSettle sale)
<if test="sale.qysSignStatus != null and sale.qysSignStatus !=''">
    AND DLCFAI.STATUS_CODE = #{sale.qysSignStatus,jdbcType=VARCHAR}
</if>

AND DLCFAI.STATUS_CODE = #{qysSignStatus}

无效的列索引
检查一下列索引

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632