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();
    }
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值