zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    内置常量
    python100练
    python之禅
    Django
    pymsql入门
    jQuery事件
    数据库(索引)
    算法基础知识
    数据库(查询专项)
    数据库(所有人都坐下!这是基本操作!)
  • 原文地址:https://www.cnblogs.com/EasonJim/p/7052368.html
Copyright © 2011-2022 走看看