多表联查问题

来源:6-3 基本配置

慕斯0313780

2020-03-18 16:19

老师好,请问我要多表联查应该怎么操作?我看教程都是单表操作呢

写回答 关注

3回答

  • 老猿
    2020-03-20 16:03:28

           MP自带的CRUD操作是针对单表操作的,如果要操作多表,可以写自定义sql。

    给你举个使用条件构造器的多表sql例子,可以写在xml中或注解中,下面的是用xml的写法:

    <select id="mySelectList" resultType="User">     
        select u.*,r.role_name from user u inner join role r on u.role_id = r.role_id ${ew.customSqlSegment}
    </select>

    对应的Mapper接口中的方法定义:

    List<User> mySelectList(@Param(Constants.WRAPPER) Wrapper<User> wrapper);

           返回值可以是VO。也可以是实体类,但要要记住,如果用实体类接返回值,实体中非该实体对应表的数据库字段的属性上要标注@TableField(exist = false),如果使用了条件构造器,条件构造器的字段名别忘了带别名。

  • qq_慕丝3367668
    2020-04-23 14:52:58

    补充

    QueryWrapper<Userinfo> qw = Wrappers.<Userinfo>query();

    qw.like("a.name","张王李赵").eq("b.labelname", "xxx");


  • 慕后端9585686
    2020-03-18 20:13:02

    可以看看mybatis的文档 用XML文件的一样的方法 



MyBatis-Plus入门

MyBatis-Plus框架入门必学课程!

56140 学习 · 381 问题

查看课程

相似问题