mp多表查询

来源:1-1 高级功能课程简介

6391229

2020-04-28 15:19

mp针对单表还是可以 但是多表联查我看了很多文档大多都是resultMap这种还是mybatis的 有mp关于多表操作吗

写回答 关注

1回答

  • 老猿
    2020-05-05 16:24:18

           多表联查可以既使用xml或@select注解的方式写sql,然后还能使用MP的条件构造器,实现方式如下:

           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),如果使用了条件构造器,条件构造器的字段名别忘了带别名。

    Stefan...

    分页的话参考https://blog.csdn.net/u011177064/article/details/104869351 自定义VO,controller里调用mapper中返回类型为List<VO>的方法

    2020-05-13 23:36:09

    共 1 条回复 >

MyBatis-Plus进阶

MyBatis-Plus框架进阶课程

23296 学习 · 118 问题

查看课程

相似问题