Mybaties多表查询

在mybatie框架中我们可以实现多表查询,但是返回的结果集需要我们进行设置才能使用,

现在我们开始举一个例子:

@Data
public class Order {

        private int id;

        private Date ordertime;

        private double total;

        //代表当前订单从属于哪一个客户

        private User user;
}
@Data
public class User {

        private int id;

        private String username;

        private String password;

        private Date birthday;
}

下面这个是多表查询的sql语句

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.itheima.mapper.OrderMapper">
    <resultMap id="orderMap" type="order">
<!--        手动指定字段与实体属性的映射关系
            column 数据表的字段的名称
            property 自定义的字段的属性-->
        <id column="oid" property="id"></id>
        <result column="ordertime" property="ordertime" ></result>
        <result column="total" property="total" ></result>
        <result column="uid" property="user.id"></result>
        <result column="username" property="user.username"></result>
        <result column="password" property="user.password"></result>
        <result column="birthday" property="user.birthday"></result>
    </resultMap>

        <select id="findAll" resultMap="orderMap">
            select * ,o.id oid  from orders o,user u where o.uid = u.id
        </select>


</mapper>

findAll这个方法是查询两个表的数据一个是user表一个是order表,在Java中我们把user表封装成User类作为一个对象属性放到了Order类中,select * ,o.id oid from orders o,user u where o.uid = u.id  查询出来的数据是这样的数据

这些结果集已经包含了user表的数据和order表的数据,但是如何取出来不能像普通的返回对象类结果集那样取,我们需要定义一个Map集合,把查出来的数据归纳好,属性一一对应给Order类中的属性,这样才能使用,

这个map集合是order类型的所以我们type为order,oid是这个集合的名字方便给其他的sql查询返回数据类型使用.其中<result >标签中的两个类型column是我们数据表中查询的列名称它对应着我们order类中id这个属性,我们把他这两个属性映射起来,这样查出来的数据就会自动的给我们的id属性set了,像ordertime、total与上文一样,一一对应着Order类中属性的ordertime、total,

但是我们需要注意下uid这个查出来表属性他是属于user类的,但是user类又属于order类中属性所以我们可以直接把他封装进user.id的属性中,就可以看成把这个数据给order类的对象属性中.id属性这样username、passowrd、birthday亦是如此与user.username、user.passowerd、user.birthday一一对应,在把这个自定义好数据类型作为查询数据的map集合封装,这样我们的多表查询就写好了.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值