myBatis3之SQL映射的XML文件(resultMap元素之六)

myBatis3之SQL映射的XML文件(resultMap元素之六)

-----------

 

 

高级结果映射之collection元素(集合)

 

<collection property="posts" ofType="domain.blog.Post"> 
	<id property="id" column="post_id"/> 
	<result property="subject" column="post_subject"/> 
	<result property="body" column="post_body"/> 
</collection>

 我们来继续上面的示例,一个博客只有一个作者。但是博客有很多文章。在博客类中,这可以由下面这样的写法来表示:

private List<Post> posts; 

要映射嵌套结果集合到List中,我们使用集合元素。就像关联元素一样,我们可以从连接中使用嵌套查询,或者嵌套结果。

 

 

集合的嵌套查询

首先,让我们看看使用嵌套查询来为博客加载文章。

<resultMap id=”blogResult” type=”Blog”> 
	<collection property="posts" javaType=”ArrayList” column="blog_id" 
		ofType="Post" select=”selectPostsForBlog”/> 
</resultMap> 
<select id=”selectBlog” parameterType=”int” resultMap=”blogResult”> 
	SELECT * FROM BLOG WHERE ID = #{id} 
</select> 
<select id=”selectPostsForBlog” parameterType=”int” resultType="Author"> 
	SELECT * FROM POST WHERE BLOG_ID = #{id} 
</select> 

这里你应该注意很多东西,但大部分代码和关联元素是非常相似的。首先,你应该注意我们使用的是集合元素。然后要注意那个新的“ofType”属性。这个属性用来区分JavaBean(或字段)属性类型和集合包含的类型来说是很重要的。所以你可以读出下面这个映射:

<collection property="posts" javaType=”ArrayList” column="blog_id" 
	ofType="Post" select=”selectPostsForBlog”/>  

读作:“在Post类型的ArrayList中的posts的集合.” 

javaType属性是不需要的,因为MyBatis在很多情况下会为你算出来。所以你可以缩短写法: 

<collection property="posts" column="blog_id" ofType="Post" select=”selectPostsForBlog”/>

 

 

集合的嵌套结果 

至此,你可以猜测集合的嵌套结果是如何来工作的,因为它和关联完全相同,除了它应用了一个“ofType”属性:

<select id="selectBlog" parameterType="int" resultMap="blogResult"> 
	select 
		B.id as blog_id, 
		B.title as blog_title, 
		B.author_id as blog_author_id, 
		P.id as post_id, 
		P.subject as post_subject, 
		P.body as post_body, 
	from Blog B 
	left outer join Post P on B.id = P.blog_id 
	where B.id = #{id} 
</select>

我们又一次联合了博客表和文章表,而且关注于保证特性,结果列标签的简单映射。现在用文章映射集合映射博客,可以简单写为:   

<resultMap id="blogResult" type="Blog"> 
	<id property=”id” column="blog_id"/> 
	<result property="title" column="blog_title"/> 
	<collection property="posts" ofType="Post"> 
		<id property="id" column="post_id"/> 
		<result property="subject" column="post_subject"/> 
		<result property="body" column="post_body"/> 
	</collection> 
</resultMap> 

同样,要记得id元素的重要性,如果你不记得了,请阅读前面blog的关联部分。 

同样,如果你引用更长的形式允许你的结果映射的更多重用,你可以使用下面这个替代的映射:

<resultMap id="blogResult" type="Blog"> 
	<id property=”id” column="blog_id" /> 
	<result property="title" column="blog_title"/> 
	<collection property="posts" ofType="Post" resultMap=”blogPostResult”/> 
</resultMap> 
<resultMap id="blogPostResult" type="Post"> 
	<id property="id" column="post_id"/> 
	<result property="subject" column="post_subject"/> 
	<result property="body" column="post_body"/> 
</resultMap> 

注意:这个对你所映射的内容没有深度,广度或关联和集合相联合的限制。当映射它们时你应该在大脑中保留它们的表现。你的应用在找到最佳方法前要一直进行的单元测试和性能测试。好在myBatis让你后来可以改变想法,而不对你的代码造成很小(或任何)影响。  

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值