解决:mybatis执行SQL语句部分参数返回NULL
来源:互联网 发布:java 线程池 获取队列 编辑:程序博客网 时间:2024/06/05 07:43
今天在写代码的时候发现一个问题: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>
日志显示:
阅读全文
0 0
- 解决:mybatis执行SQL语句部分参数返回NULL
- Mybatis selectOne方法执行sql有数据返回为null
- mybatis执行sql语句
- mybatis直接执行sql语句
- mybatis直接执行sql语句
- mybatis直接执行sql语句
- mybatis 打印sql执行语句
- mybatis执行动态sql语句
- MyBatis中,传String类型参数到xml配置文件,并执行SQL语句后返回String类型的结果写法(jeesite)
- 执行sql 返回 参数结果
- 可能返回 null 的 SQL 语句
- mybatis插入语句执行后返回结果
- mybatis直接执行前台传递的sql语句(mapper参数即为sql字符串)
- MyBatis主流程分析之(三)-准备SQL语句和参数替换、执行
- mybatis sql语句返回值问题
- entity framework(EF) 直接执行数据库命令并返回DataTable 参数化sql语句
- Entity Framework(EF) 直接执行数据库命令并返回 DataTable 数据参数化 SQL 语句
- SQL语句各个部分的执行顺序
- LeetCode之Keyboard Row
- spring的@Transactional注解详细用法
- 关于职业生涯的一点思考
- Android版本更新
- 查找方法总结---待完善
- 解决:mybatis执行SQL语句部分参数返回NULL
- js--排序算法
- Git-2017-06-11 20:17:19
- 项目的搭建环境1
- 洛谷Oj-队列安排-模拟双向链表
- 数据结构 哈希表的原理和代码实现
- 输入输出流对象
- 将虚拟机的ip改成固定的ip地址
- php程序员的技术成长规划