为了账号安全,请及时绑定邮箱和手机立即绑定

请问老师,mybatis-plus中有多表连接动态条件查询的优化方案吗

jpa对单表操作很方便,但是项目中如果经常出现表连接动态条件分页查询的需求,按mybatis的方式就是去xml中写sql实现,比较繁琐,也很重要,老师能否讲解一下遇到这种需求怎么办,有没有更优美的做法可以使用呢

正在回答

1 回答

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

2 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

请问老师,mybatis-plus中有多表连接动态条件查询的优化方案吗

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信