MyBatis 表连接查询写法|三种对应关系

❤️作者主页:微凉秋意
✅作者简介:后端领域优质创作者🏆,CSDN内容合伙人🏆,阿里云专家博主🏆
✨精品专栏:C++面向对象
🔥系列专栏:JavaWeb


前言

上篇博文把基础部分记录了,本篇是对 表连接查询 中一对一,一对多,多对多关系写法区别的记录总结。

表连接查询

  • 前提最少是两张表,其中的子表设有外键
  • 按对应关系可分为:
    • 一对一
    • 一对多
    • 多对多

对于主外键的关系搞不清楚的可以参考我以往的博文:mysql一点通

一对一关系

有如下两张表格,t_people(人)与t_passport(护照):

在这里插入图片描述
在这里插入图片描述

一个人对应一本护照,同时一本护照对应一个人,而且人不一定有护照,有护照一定会有人存在。
因此外键应设在护照表中,那么就该创建类了:

// Passport:
public class Passport {
    private Integer passportId;
    private String passportSerial;
}
// People
public class People {
    private Integer peopleId;
    private String  peopleName;
    private Passport passport;
}

这样创建非常符合表之间的逻辑关系,但是创建方式并不唯一。
在Passport类中添加People属性也是可以的,即:

// Passport
public class Passport {
    private Integer passportId;
    private String passportSerial;
    private People people;
}
// People
public class People {
    private Integer peopleId;
    private String  peopleName;
}

那实际做项目时应该如何取舍?答案是根据需求:

  • 如果是查询公民以及其对应的护照信息,那就用前者
  • 如果是查询所有护照以及持有者的信息,那就用后者
  • 因此在设计类时不要太死板,两种方法需要斟酌后选择

这里以查询公民以及其对应的护照信息为例,编写项目:

在mapper接口定义方法:

public interface PeopleMapper {
    List<People> selectAll();
}

在xml中编写sql:

<mapper namespace="com.qj.mapper.PeopleMapper">
    <resultMap id="peopleMap" type="People">
        <id property="peopleId" column="people_id"/>
        <result property="peopleName" column="people_name"/>
        <association property="passport" javaType="Passport">
            <id property="passportId" column="passport_id"/>
            <result property="passportSerial" column="passport_serial"/>
        </association>
    </resultMap>

    <select id="selectAll" resultMap="peopleMap">
        select *
        from t_people t1
                 left join t_passport t2 on t1.people_id = t2.people_id
    </select>
</mapper>

重点在于resultMap里的写法:

  • association 标签用于一对一关系:
    • propetry 后写属性名
    • javaType 后写该属性所属类的类型

编写测试类:

public static void main(String[] args) {
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    PeopleMapper mapper = sqlSession.getMapper(PeopleMapper.class);
    mapper.selectAll().forEach(System.out::println);
    MybatisUtil.closeSqlSession(sqlSession);
}

这段代码:mapper.selectAll().forEach(System.out::println); 中的写法是在JDK1.8之后有的:

  • 格式:集合.foreach(打印方法)

运行结果:
在这里插入图片描述

一对多关系

有如下两张表格,t_user(用户),t_order(订单):
在这里插入图片描述
在这里插入图片描述

用户可以下多个订单,一个订单对应一个用户,这就是一种一对多关系。

查询用户及其所有订单信息:

// Order
public class Order {
    private Integer orderId;
    private String orderName;
}
// User
public class User {
    private Integer uId;
    private String userName;
    private String userPwd;
    private List<Order> orders;
}

xml文件的写法:

<mapper namespace="com.qj.mapper.UserMapper">
    <resultMap id="userMap" type="User">
        <id property="uId" column="u_id"/>
        <result property="userName" column="u_username"/>
        <result property="userPwd" column="u_pwd"/>
        <collection property="orders" javaType="java.util.List" ofType="Order">
            <id property="orderId" column="order_id"/>
            <result property="orderName" column="order_name"/>
        </collection>
    </resultMap>

    <select id="selectAll" resultMap="userMap">
        select *
        from t_user t1
                 left join t_order t2
                           on t1.u_id = t2.user_id
    </select>

</mapper>

这里与一对一的区别就在于使用的标签不同:

  • collection 标签:
    • property后写属性名
    • javaType后写集合类型
    • ofType后写泛型的类型

测试结果:
在这里插入图片描述

多对多关系

有以下三张表格,表示了学生的选课情况:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

一个学生可以选多个课程,而一个课程可以被多个学生选择,这就是典型的多对多关系。

而 多对多 与 一对多 关系在xml文件中resultMap的写法几乎一致,因此不做过多解释,看一下sql 语句与测试结果即可:

<select id="selectAll" resultMap="stuMap">
        select *
        from t_stu t1
                 left join t_sc t2 on t1.stu_id = t2.s_id
                 left join t_course t3 on t3.course_id = t2.c_id
    </select>

在这里插入图片描述


下篇总结 mybatis 动态sql、常用的标签以及缓存的有关知识,需要的小伙伴记得订阅专栏。

  • 62
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 52
    评论
<h3>回答1:</h3><br/>您好!对于MyBatis-Plus多查询,可以通过以下几种方式实现: 1.使用MyBatis-Plus的Wrapper查询条件构造器,可以通过连查询多张。例如: ```java QueryWrapper<User> wrapper = new QueryWrapper<>(); wrapper.select("user.id", "user.name", "dept.dept_name") .eq("user.dept_id", "dept.id") .like("user.name", "Tom"); List<User> userList = userMapper.selectList(wrapper); ``` 其中,`select`方法指定要查询的字段,`eq`方法指定关联条件,`like`方法指定查询条件,`userMapper`为MyBatis-Plus提供的Mapper对象。 2.使用MyBatis-Plus的Join查询,可以通过`leftJoin`、`rightJoin`等方法实现多连接查询。例如: ```java LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>(); wrapper.select(User::getId, User::getName, Dept::getDeptName) .eq(User::getDeptId, 1) .leftJoin(Dept.class, User::getDeptId, Dept::getId); List<User> userList = userMapper.selectList(wrapper); ``` 其中,`leftJoin`方法指定要连接及其连接条件,`User::getDeptId`示User的dept_id字段,`Dept::getId`示Dept的id字段。 3.使用MyBatis-Plus的自定义SQL查询,可以编写自己的SQL语句实现多连接查询。例如: ```java @Select("SELECT u.id, u.name, d.dept_name FROM user u LEFT JOIN dept d ON u.dept_id = d.id WHERE u.name like '%Tom%'") List<UserDeptDTO> getUserDeptList(); ``` 其中,`@Select`注解指定要执行的SQL语句,`UserDeptDTO`为自定义的DTO对象,用于接收查询结果。 以上是MyBatis-Plus多连接查询的几种方式,希望对您有帮助。如有疑问,欢迎继续咨询! <h3>回答2:</h3><br/>Mybatis-Plus是一个在Mybatis基础上的增强工具,提供了很多方便的功能,其中之一就是多连接查询。在实际应用中,我们常常需要查询多个中的数据来满足业务需求,这时使用Mybatis-Plus的多连接查询功能就能大大提高开发效率。 Mybatis-Plus提供了三种连接查询的方式: 1. Wrapper方式:Wrapper是Mybatis-Plus提供的一种条件构造器,用于构建查询条件。我们可以使用Wrapper来构建多连接查询的条件,并将Wrapper作为参数传入Mybatis-Plus的selectList方法中,来实现多连接查询。 2. EntityWrapper方式:EntityWrapper是Wrapper的一个子类,它提供了更加方便的方法来构造查询条件。我们可以使用EntityWrapper来构建多连接查询的条件,并将EntityWrapper作为参数传入Mybatis-Plus的selectList方法中,来实现多连接查询。 3. QueryWrapper方式:QueryWrapper是Mybatis-Plus提供的针对实体类的条件构造器,它可以帮助我们更加方便地构建查询条件。我们可以使用QueryWrapper来构建多连接查询的条件,并将QueryWrapper作为参数传入Mybatis-Plus的selectList方法中,来实现多连接查询。 在使用Mybatis-Plus的多连接查询功能时,需要注意以下几点: 1. 数据库中相关需要有关联关系,否则无法完成多连接查询。 2. 在构建查询条件时,需要注意别名的使用,避免出现列名不唯一或语法错误等问题。 3. 在实际查询中,要注意关联查询产生的数据量问题,尽量避免无意义的全扫描和大量数据的返回。 总之,Mybatis-Plus的多连接查询功能可以帮助我们更加方便地完成多查询操作,提高开发效率。在使用时,需要结合实际业务需求和数据库结构,灵活搭配使用各种查询方式,以达到最优的查询效果。 <h3>回答3:</h3><br/>Mybatis Plus是Mybatis的增强版本,它提供了更加方便的使用方式和更加强大的功能。在多连接查询方面,Mybatis Plus也提供了许多支持,可以大大简化我们的开发流程。 在Mybatis Plus中,多连接查询可以通过以下几种方式实现: 1.使用XML配置文件进行多连接查询 在XML配置文件中,可以直接使用SQL原生语句进行多连接查询。例如: ```xml <select id="queryUserAndOrder" resultMap="userAndOrderResultMap"> SELECT * FROM user INNER JOIN order ON user.id = order.user_id; </select> ``` 2.使用Mybatis Plus提供的Wrapper类进行多连接查询 Wrapper类是Mybatis Plus中一个非常重要的类,它封装了各种条件查询方法,包括多连接查询。一般来说,我们可以直接使用Mybatis Plus提供的Wrapper类进行多连接查询。例如: ```java List<UserAndOrderDTO> userAndOrderList = userMapper.selectList( Wrappers.<User>lambdaQuery() .select(User::getId, User::getName, Order::getId, Order::getOrderNo) .eq(User::getId, 1) .leftJoin(Order.class, Order::getUserId, User::getId) ); ``` 该方法采用了lambda达式的方式进行条件查询,通过leftJoin方法可以实现User和Order的左连接操作。 3.使用Mybatis Plus提供的QueryWrapper和JoinWrapper进行多连接查询 QueryWrapper和JoinWrapper也是Mybatis Plus中非常重要的类,它可以用来进行更加灵活的多连接查询。例如: ```java QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.select(User.class, "id", "name", "order_no") .eq("id", 1) .leftJoin("order", "user.id = order.user_id"); List<Map<String, Object>> list = userMapper.selectMaps(queryWrapper); ``` 以上就是Mybatis Plus多连接查询三种方式。根据实际开发需求,选择适合的方式可以大大提升开发效率和代码质量。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

微凉秋意

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值