MyBatis-Plus--多表联查(动态查询)

简介
本文用示例介绍使用MyBatis-Plus进行多表查询的方法,包括静态查询和动态查询。

代码
controller

package com.example.demo.business.blog.controller;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.example.demo.business.blog.mapper.BlogMapper;
import com.example.demo.business.blog.vo.BlogVO;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
@Api(tags = "自定义SQL")
@RestController
@RequestMapping("/blog")
public class BlogController {
 
    @Autowired
    private BlogMapper blogMapper;
 
    @ApiOperation("静态查询")
    @GetMapping("staticQuery")
    public String staticQuery() {
        return blogMapper.findUserNameByBlogId(1L);
    }
 
    @ApiOperation("动态查询")
    @GetMapping("dynamicQuery")
    public IPage<BlogVO> dynamicQuery(Page<BlogVO> page, String nickName, String title) {
        QueryWrapper<BlogVO> queryWrapper = new QueryWrapper<>();
        queryWrapper.like(StringUtils.hasText(nickName), "t_user.nick_name", nickName);
        queryWrapper.like(StringUtils.hasText(title), "t_blog.title", title);
        queryWrapper.eq("t_blog.deleted_flag", 0);
        queryWrapper.eq("t_user.deleted_flag", 0);
        queryWrapper.apply("t_blog.user_id = t_user.id");
        return blogMapper.findBlog(page, queryWrapper);
    }
 
    @ApiOperation("动态查询(使用join)")
    @GetMapping("dynamicQueryByJoin")
    public IPage<BlogVO> dynamicQueryByJoin(Page<BlogVO> page, String nickName, String title) {
        QueryWrapper<BlogVO> queryWrapper = new QueryWrapper<>();
        queryWrapper.like(StringUtils.hasText(nickName), "t_user.nick_name", nickName);
        queryWrapper.like(StringUtils.hasText(title), "t_blog.title", title);
        queryWrapper.eq("t_blog.deleted_flag", 0);
        return blogMapper.findBlogByJoin(page, queryWrapper);
    }
}
 Mapper

package com.example.demo.business.blog.mapper;
 
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.example.demo.business.blog.entity.Blog;
import com.example.demo.business.blog.vo.BlogVO;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.springframework.stereotype.Repository;
 
import java.util.List;
 
@Repository
public interface BlogMapper extends BaseMapper<Blog> {
 
    /**
     * 静态查询
     */
    @Select("SELECT t_user.user_name " +
            " FROM t_blog, t_user " +
            " WHERE t_blog.id = #{id} " +
            "     AND t_blog.user_id = t_user.id")
    String findUserNameByBlogId(@Param("id") Long id);
 
    /**
     * 动态查询
     */
    @Select("SELECT * " +
            " FROM t_blog, t_user " +
            " ${ew.customSqlSegment} ")
    IPage<BlogVO> findBlog(IPage<BlogVO> page, @Param("ew") Wrapper wrapper);
 
    /**
     * 动态查询(通过join)
     */
    @Select(&#

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值