前提:
1、新建Article表和增加模擬數據,腳本如下:
Drop TABLE IF EXISTS `article`; Create TABLE `article` ( `id` int(11) NOT NULL auto_increment, `userid` int(11) NOT NULL, `title` varchar(100) NOT NULL, `content` text NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8; Insert INTO `article` VALUES ('1', '1', 'test_title', 'test_content'); Insert INTO `article` VALUES ('2', '1', 'test_title_2', 'test_content_2'); Insert INTO `article` VALUES ('3', '1', 'test_title_3', 'test_content_3'); Insert INTO `article` VALUES ('4', '1', 'test_title_4', 'test_content_4');
實現步驟,也是多對一的實現:
1、新建Article的類,也就是POJOs,與上面新建的article表一一對應,代碼如下:
package com.jsoft.testmybatis.models; public class Article { private int id; private User user; private String title; private String content; public int getId() { return id; } public void setId(int id) { this.id = id; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } public String getContent() { return content; } public void setContent(String content) { this.content = content; } }
注意:文章的用戶是怎么定義的,是直接定義的一個User對象,而不是int類型。
2、配置User.xml,這里要引入association,實現多對一,也就是查詢這個用戶所關聯的文章列表,定義如下:
<!-- User聯合文章進行查詢方法之一的配置 (多對一的方式) --> <resultMap id="resultUserArticleList" type="Article"> <id property="id" column="aid" /> <result property="title" column="title" /> <result property="content" column="content" /> <association property="user" javaType="User"> <id property="id" column="id" /> <result property="userName" column="userName" /> <result property="userAddress" column="userAddress" /> </association> </resultMap> <select id="getUserArticles" parameterType="int" resultMap="resultUserArticleList"> select user.id,user.userName,user.userAddress,article.id as aid,article.title,article.content from user,article where user.id=article.userid and user.id=#{id} </select>
用association來得到關聯的用戶,這是多對一的情況,因為所有的文章都是同一個用戶的。
還有另外一種處理方式,可以復用前面已經定義好的resultMap,前面定義過一個resultListUser,定義如下:
<!-- User 聯合文章進行查詢 方法之二的配置 (多對一的方式) --> <resultMap id="resultUserArticleList-2" type="Article"> <id property="id" column="aid" /> <result property="title" column="title" /> <result property="content" column="content" /> <association property="user" javaType="User" resultMap="resultListUser" /> </resultMap>
3、在IUserOperation接口中加入select對應的id名稱相同的方法:
public List<Article> getUserArticles(int id);
4、在Configuration.xml中配置typeAliases:
<typeAliases> <typeAlias alias="Article" type="com.jsoft.testmybatis.models.Article" /> </typeAliases>
5、測試核心代碼:
List<Article> articles = userOperation.getUserArticles(1); for (Article article : articles) { System.out.println( article.getTitle() + ":" + article.getContent() + ":作者是:" + article.getUser().getUserName() + ":地址:" + article.getUser().getUserAddress()); }
6、測試結果:
測試工程:https://github.com/easonjim/5_java_example/tree/master/mybatis/test4
參考: