mybatis多表關聯查詢(一對多)

一 概述

一個用戶可以擁有多個訂單,可以在用戶pojo類中添加一個泛型爲Orders的集合
方法:
1.映射文件中使用resultMap配置
2. 用戶表中加List< Orders > orderList屬性

二 案例代碼

目標:查詢指定用戶的訂單

1.寫sql語句

SELECT u.id,u.username,o.id oid,o.number,o.createtime,o.note from user u LEFT JOIN orders o on u.id=o.user_id and u.id=1

2. pojo類(user類添加訂單list)

public class User implements Serializable {
    private Integer id;
    private String username;// 用戶姓名
    private String sex;// 性別
    private Date birthday;// 生日
    private String address;// 地址
    private List<Orders> orders;
    public List<Orders> getOrders() {
        return orders;
    }
    public void setOrders(List<Orders> orders) {
        this.orders = orders;
    }
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }
    public Date getBirthday() {
        return birthday;
    }
    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    }
    public String getAddress() {
        return address;
    }
    public void setAddress(String address) {
        this.address = address;
    }
    @Override
    public String toString() {
        return "User [id=" + id + ", username=" + username + ", sex=" + sex
                + ", birthday=" + birthday + ", address=" + address + "]";
    }




}

3.映射文件配置sql語句

<resultMap type="User" id="UserOrderResultMap">
        <id property="id" column="id"/>
        <result property="username" column="username"/>

        <!-- List<Orders>配置 -->
        <collection property="orders" ofType="Orders">
            <id property="id" column="oid"/>
            <result property="number" column="number"/>
            <result property="createtime" column="createtime"/>
            <result property="note" column="note"/>
        </collection>
    </resultMap>
    <!--查詢用戶id,用戶名及其訂單  -->
    <select id="findUserWithOrders" parameterType="int" resultMap="UserOrderResultMap">
        SELECT 
            u.id,
            u.username,
            o.id oid,
            o.number,
            o.createtime,
            o.note
        from user u 
        LEFT JOIN orders o 
        on u.id=o.user_id and u.id=#{id}
    </select>

4.接口中定義對應方法

public interface UserDao {
//  public List<User> findUserByQueryVo(QueryVo queryVo);
    public List<User> findUserWithOrders(int id);
}

5.測試

package com.itheima.test;

import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;

import com.itheima.domain.OrderWithCutomer;
import com.itheima.domain.Orders;
import com.itheima.domain.QueryVo;
import com.itheima.domain.User;
import com.itheima.mapperTest.OrdersDao;
import com.itheima.mapperTest.UserDao;

public class UserOperateTest2 {

    private SqlSessionFactory sqlSessionFactory;
    @Before
    public void setSqlSession() throws Exception{
        //1.獲得SqlSession對象
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");
        sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream);
    }

    @Test
    public void testFindOrderWithCustomer() throws Exception{
        //1.獲得SqlSession對象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //2.獲得接口的代理對象   sqlSession.getMapper()
        UserDao userDao = sqlSession.getMapper(UserDao.class);
        //3.使用代理對象的方法操作
        List<User> userWithOrders = userDao.findUserWithOrders(1);
        for (User user : userWithOrders) {
            System.out.println(user.getUsername());
            List<Orders> orders = user.getOrders();
            for (Orders orders2 : orders) {
                System.out.println(orders2);
            }
        }
        //4.釋放資源
        sqlSession.close();
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章