解决:mybatis执行SQL语句部分参数返回NULL

今天在写代码的时候发现一个问题:mybatis执行sql语句的时候返回bean的部分属性为null,在数据库中执行该sql语句能够正常返回,把相关代码反反复复翻了个遍,甚至都重启eclipse了,依旧没解决问题,后来网上搜了一下,还真有类似的问题

闲话少说,直接说问题,该sql语句是自己写的,resultType直接用了该bean全名称,最终导致部分属性显示为null,

原来的写法:

 <select id="selectByArticle" parameterType="com.pet.bean.Article" resultMap="com.pet.bean.Article">
  	SELECT <include refid="Base_Column_List"/> 
  	FROM ARTICLE
   <where>
   		<include refid="com.pet.mapper.ArticleMapper.queryCondition" />
   </where> 
  </select>
<sql id="queryCondition">
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(id)">AND ID = #{id,jdbcType=Integer}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(authorName)">AND AUTHOR_NAME = #{authorName,jdbcType=VARCHAR}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(title)">AND TITLE = #{title,jdbcType=VARCHAR}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(content)">AND CONTENT = #{content,jdbcType=VARCHAR}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(makeTime)">AND MAKE_TIME = #{makeTime,jdbcType=VARCHAR}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(updateTime)">AND UPDATE_TIME = #{updateTime,jdbcType=VARCHAR}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(kind)">AND KIND = #{kind,jdbcType=VARCHAR}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(about)">AND ABOUT = #{about,jdbcType=VARCHAR}</if>
	<if test="@org.apache.commons.lang.StringUtils@isNotBlank(status)">AND STATUS = #{status,jdbcType=VARCHAR}</if>
	</sql>
	


部分代码:



日志显示:

修改后的写法:resultType改成了resultMap了

<select id="selectByArticle" parameterType="com.pet.bean.Article" resultMap="BaseResultMap">
  	SELECT <include refid="Base_Column_List"/> 
  	FROM ARTICLE
   <where>
   		<include refid="com.pet.mapper.ArticleMapper.queryCondition" />
   </where> 
  	
  </select>
  <resultMap id="BaseResultMap" type="com.pet.bean.Article" >
    <id column="ID" property="id" jdbcType="INTEGER" />
    <result column="AUTHOR_NAME" property="authorName" jdbcType="VARCHAR" />
    <result column="TITLE" property="title" jdbcType="VARCHAR" />
    <result column="CONTENT" property="content" jdbcType="VARCHAR" />
    <result column="MAKE_TIME" property="makeTime" jdbcType="VARCHAR" />
    <result column="UPDATE_TIME" property="updateTime" jdbcType="VARCHAR" />
    <result column="KIND" property="kind" jdbcType="VARCHAR" />
    <result column="ABOUT" property="about" jdbcType="VARCHAR" />
  </resultMap>
 


日志显示:


mybatis执行sql语句部分参数返回null问题通常是由于参数类型与实际传入参数类型不匹配导致的。为了解决这个问题,我们需要对参数进行调试和检查。下面,我们提供几种常用的解决方案。 1.在SqlMapper.xml中添加参数类型 在SqlMapper.xml文件中对参数类型进行明确声明,可以避免参数传递出现歧义。例如,在参数为字符串类型时,可以使用如下的方式声明参数类型: <parameterMap type="java.lang.String" /> 2.修改Java对象对应的类 在Java对象对应的类中,修改该属性的类型,使其与数据库对应的列类型一致。例如,如果数据库中的列为varchar类型,就需要将Java对象的类对应属性的类型设置为String类型。 3.使用TypeHandler 通过使用TypeHandler,可以将Java对象的属性映射到数据库中对应的列上,避免了参数类型不匹配的情况。例如,对于通过Java对象传递的时间,可使用如下的TypeHandler实现对时间进行转换: public class DateTypeHandler extends BaseTypeHandler<Date> { @Override public void setNonNullParameter(PreparedStatement ps, int i, Date parameter, JdbcType jdbcType) throws SQLException { ps.setTimestamp(i, new Timestamp(parameter.getTime())); } @Override public Date getNullableResult(ResultSet rs, String columnName) throws SQLException { return new Date(rs.getTimestamp(columnName).getTime()); } @Override public Date getNullableResult(ResultSet rs, int columnIndex) throws SQLException { return new Date(rs.getTimestamp(columnIndex).getTime()); } @Override public Date getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { return new Date(cs.getTimestamp(columnIndex).getTime()); } } 使用TypeHandler,可以将Java对象的属性与数据库对应的列进行映射,解决参数类型不匹配的问题。 总之,解决mybatis执行sql语句部分参数返回null问题需要认真检查参数类型的匹配问题,并对参数类型进行适当的调整和配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东天里的冬天

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值