本节讲 高级查询。
场景:一个博客文章一定有一个作者,通过一个 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>
是不是很方便呢。
完整代码示例见:https://github.com/vir56k/java_demo/tree/master/mybatisdemo6_query1
场景:假设一个作者有多个文章,在文章表记录了作者的 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;
}
从打印的结果可以看到,数据库返回了 3条记录。而 mybatis 进行映射充足后,合并了重复项,list 集合中只有两条。
我的代码示例见:https://github.com/vir56k/java_demo/tree/master/mybatisdemo6_query2