MyBatis 学习笔记(6) 关联查询

1. 背景

本节讲 高级查询。

2.关联查询

2.1 一对一映射:直接将结果写入到关联对象中

场景:一个博客文章一定有一个作者,通过一个 authorId 关联。
mybatis 可以支持这样左连接查询,一次性查出结果,还能将结果集直接写入到关联 的 author 对象中。

示例:

public class Blog {
    public long id;
    public String blogTitle;
    public String blogContent;
    public String authorId;

    public Author author;

}

public class Author {
    public long id;
    public String userName;
    public String userInfo;
}

xml映射文件:

<select id="selectBlogList" resultMap="blogResult">
        select
          blog_title,
          blog_content ,
          author_id,
          A.user_name as 'author.userName',
          A.id as 'author.id'
        FROM blog as B LEFT JOIN author AS A ON B.author_id = A.id
    </select>
  • 注意这里用了别名, A.user_name as 'author.userName'。正是这句话实现了直接写入到 author 对象的 userName 自动中。mybatis 直接帮我们new 了一个 author ,并写入属性值。

是不是很方便呢。

完整代码示例见:https://github.com/vir56k/java_demo/tree/master/mybatisdemo6_query1

2.2 一对多映射:关联多个对象放入一个属性的集合中

场景:假设一个作者有多个文章,在文章表记录了作者的 auther_id。想一次查出 作者和作者所有的文章。

mybatis 的 <collection> 标签 用于在关联关系中描述一个集合。
示例:

<mapper namespace="cn.zyfvir.AuthorMapper">

    <resultMap id="authorResult" type="cn.zyfvir.Author">
        <id property="id" column="id"/>
        <result property="userName" column="user_name"/>
        <result property="userInfo" column="user_info"/>
        <collection property="blogList" ofType="cn.zyfvir.Blog" columnPrefix="blog.">
            <id property="id" column="id"/>
            <result property="blogTitle" column="blog_title"/>
            <result property="blogContent" column="blog_content"/>
        </collection>
    </resultMap>

    <select id="selectAuthorList" resultMap="authorResult">
        select
          A.id,
          A.user_name,
          B.id as 'blog.id',
          B.blog_title as 'blog.blog_title',
          B.blog_content as 'blog.blog_content'
        FROM author AS A LEFT JOIN blog as B ON B.author_id = A.id
    </select>
</mapper>

java 实体类定义:

public class Author {
    public long id;
    public String userName;
    public String userInfo;
    public List<Blog> blogList;
}
public class Blog {
    public long id;
    public String blogTitle;
    public String blogContent;
    public String authorId;
}
  • 在这个实体类定义中,blog 集合是author 的字段,它是list类型。
  • mybatis 会针对 id 做过滤重复的对象。

从打印的结果可以看到,数据库返回了 3条记录。而 mybatis 进行映射充足后,合并了重复项,list 集合中只有两条。

我的代码示例见:https://github.com/vir56k/java_demo/tree/master/mybatisdemo6_query2

3.参考:

https://mybatis.org/mybatis-3/zh/sqlmap-xml.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值