联表怎么查询呢?

来源:4-2 分页查询

江湖卖药的

2020-08-17 12:37

老师,该联表怎么查询呢?

写回答 关注

1回答

  • 老猿
    2020-08-30 18:24:33

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

    墨12332...

    老师,在你的给的代码中,如果需要使用${ew.customSqlSegment}中的查询条件,在传入wrapper中得设置wrapper.eq("u.id", xxxxx)才能正确查询。这样每一个查询条件都需要加一个"u."的前缀,这样在多人开发的时候很容易出现错误。有没有好的办法处理?我目前的想法是用反射,把查询条件的包装类转换成wrapper对象

    2023-07-11 17:00:23

    共 1 条回复 >

MyBatis-Plus入门

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

56140 学习 · 381 问题

查看课程

相似问题