今天在写代码的时候发现一个问题:mybatis执行sql语句的时候返回bean的部分属性为null,在数据库中执行该sql语句能够正常返回,把相关代码反反复复翻了个遍,甚至都重启eclipse了,依旧没解决问题,后来网上搜了一下,还真有类似的问题。
闲话少说,直接说问题,该sql语句是自己写的,resultType直接用了该bean全名称,最终导致部分属性显示为null,
原来的写法:
- <selectid="selectByArticle"parametertype="com.pet.bean.Article"resultmap="com.pet.bean.Article">
- SELECT
- FROMARTICLE
- </select>
- <sqlid="queryCondition">
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(id)">ANDID=#{id,jdbcType=Integer}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(authorName)">ANDAUTHOR_NAME=#{authorName,jdbcType=VARCHAR}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(title)">ANDTITLE=#{title,jdbcType=VARCHAR}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(content)">ANDCONTENT=#{content,jdbcType=VARCHAR}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(makeTime)">ANDMAKE_TIME=#{makeTime,jdbcType=VARCHAR}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(updateTime)">ANDUPDATE_TIME=#{updateTime,jdbcType=VARCHAR}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(kind)">ANDKIND=#{kind,jdbcType=VARCHAR}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(about)">ANDABOUT=#{about,jdbcType=VARCHAR}</if>
- <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(status)">ANDSTATUS=#{status,jdbcType=VARCHAR}</if>
- </sql>
部分代码:
日志显示:
修改后的写法:resultType改成了resultMap了
- <selectid="selectByArticle"parametertype="com.pet.bean.Article"resultmap="BaseResultMap">
- SELECT
- FROMARTICLE
- </select>
- <resultmapid="BaseResultMap"type="com.pet.bean.Article">
- <idcolumn="ID"jdbctype="INTEGER"property="id">
- <resultcolumn="AUTHOR_NAME"jdbctype="VARCHAR"property="authorName">
- <resultcolumn="TITLE"jdbctype="VARCHAR"property="title">
- <resultcolumn="CONTENT"jdbctype="VARCHAR"property="content">
- <resultcolumn="MAKE_TIME"jdbctype="VARCHAR"property="makeTime">
- <resultcolumn="UPDATE_TIME"jdbctype="VARCHAR"property="updateTime">
- <resultcolumn="KIND"jdbctype="VARCHAR"property="kind">
- <resultcolumn="ABOUT"jdbctype="VARCHAR"property="about">
- </result></result></result></result></result></result></result></id></resultmap>
日志显示:
以上所述是小编给大家介绍的解决mybatis执行SQL语句部分参数返回NULL问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对快网idc网站的支持!
相关文章
             猜你喜欢
        
        - 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
- ASP.NET自助建站系统的域名绑定与解析教程 2025-06-10
 
        



 
    		 
            	 
															 
         
        
 
                        