MyBatis3-實現多表關聯數據的查詢


前提:

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

 

參考:

http://www.yihaomen.com/article/java/306.htm


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM