在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集合封装,这样我们的多表查询就写好了.