文章详情
当实体类属性和数据库不一致时,使用mybatis查询数据库返回实体类自动封装就会出现问题。针对这种情况,有两种解决方案。
1、使用别名查询
<!-- 配置查询所有操作 -->
<select id="findAll" resultType="com.itheima.domain.User">
select id as userId,username as userName,birthday as userBirthday,
sex as userSex,address as userAddress from user
</select>
优点:查询效率高
缺点:如果我们的查询很多,都使用别名的话写起来很麻烦
2、定义resultMap
resultMap 标签可以建立查询的列名和实体类的属性名称不一致时建立对应关系。从而实现封装。在 select 标签中使用 resultMap 属性指定引用即可。同时 resultMap 可以实现将查询结果映射为复杂类型的 pojo,比如在查询结果映射对象中包括 pojo 和 list 实现一对一查询和一对多查询。
<!-- 建立User实体和数据库表的对应关系
type属性:指定实体类的全限定类名
id属性:给定一个唯一标识,是给查询select 标签引用的。-->
<resultMap type="com.itheima.domain.User" id="userMap">
<id column="id" property="userId"/>
<result column="username" property="userName"/>
<result column="sex" property="userSex"/>
<result column="address" property="userAddress"/>
<result column="birthday" property="userBirthday"/>
</resultMap>
<!--id 标签:用于指定主键字段
result 标签:用于指定非主键字段
column 属性:用于指定数据库列名
property 属性:用于指定实体类属性名称-->
<!-- 配置查询所有操作-->
<select id="findAll" resultMap="userMap">
select * from user
</select>
优点:代码书写简洁,提高开发效率
缺点:查询效率低
以上就是本文的全部内容,希望对大家的学习有所帮助。
您可能感兴趣的文章:
- MyBatis注解开发:自定义映射关系与关联查询实现
- MyBatis实现批量插入方法实例
- mybatis-plus自带QueryWrapper自定义sql实现复杂查询实例详解
- mybatis-plus分页传入参数后sql where条件没有limit分页信息操作
- 解决Mybatis返回update后影响的行数问题
- Mybatis动态SQL实例详解
- 关于IDEA 2020使用 mybatis-log-plugin插件的问题
- Mybatis批量修改时出现报错问题解决方案
版权:版权申明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 70068002@qq.com 举报,一经查实,本站将立刻删除。
转载请注明出处:https://www.stntk.com/2602.html/dongtai/houduan/
还没有评论呢,快来抢沙发~