文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mybatis-Plus多表关联查询的使用案例解析

2023-05-20 05:58

关注

项目的目录结构:

有以下四个包:

1、 controller控制层

2、dao层, 项目的目录结构: 有以下四个包:

1、 controller控制层

2、dao层,接口

3、pojo,shiulilei

4、service服务层

有表结构如下:

部门表:dept

员工表:emp

假设要查询每个员工所属的部门(或位置等信息),就需要将两张表连接起来,使用SQL语句很简单(select * from emp,dept where emp.deptno=dept.deptno),但是在Java程序中怎么写就比较复杂了。

 首先配置pom.xml配置文件

1.pojo包中有dept和emp两个实例类

1)dept

@Data
@EqualsAndHashCode(callSuper = false)
@TableName("dept")
public class Dept implements Serializable {
    private static final long serialVersionUID = 1L;
    @TableId
    private Integer deptno;
    private String dname;
    private String loc;
}

 2)emp

@Data
@EqualsAndHashCode(callSuper = false)
@TableName("emp")
public class Emp implements Serializable {
    private static final long serialVersionUID = 1L;
    @TableId("empno")
    private Integer empno;
    private String ename;
    private String job;
    private Integer mgr;
    private LocalDateTime hiredate;
    private BigDecimal sal;
    private BigDecimal comm;
    private Integer deptno;
    private Dept dept;//多表关联需要查询的数据
}

 在Emp类中多了一个Dept对象,这个对象包含了每个员工对应部门的信息。

2.在Emp的mapper映射文件(.xml)中的mapper之间添加如下代码

<mapper namespace="com.nb.spring_boot.api.dao.IEmpDao">
    <resultMap id="empMapper" type="com.nb.spring_boot.api.pojo.Emp">
        <association property="dept" column="deptno" select="com.nb.spring_boot.api.dao.IDeptDao.selectById"/>
    </resultMap>
    <select id="queryEmps" resultMap="empMapper">
        select * from emp
    </select>
</mapper>

resultMap里的id属性(empMapper)里面可以随便写一个变量名,可以不叫empMapper,select里的selectById在IDeptDao接口中要有该方法

Dept selectById(Integer deptno);

3.在Dept的mapper映射文件(.xml)中的mapper之间添加如下代码

<select id="selectById" resultType="com.nb.spring_boot.api.pojo.Dept">
        select * from dept where deptno=#{deptno}
</select>

4.在IDeptDao接口中代码如下

public interface IDeptDao extends BaseMapper<Dept> {
    Dept selectById(Integer deptno);
}

5.Emp的dao接口中和

public interface IEmpDao extends BaseMapper<Emp> {
    IPage<Emp> queryEmps(IPage<Emp> page,@Param(Constants.WRAPPER) Wrapper<Emp> wrapper);
}

6.IEmpService接口中

public interface IEmpService extends IService<Emp> {
    IPage<Emp> queryEmps(IPage<Emp> result, QueryWrapper<Emp> wrapper);
}

7.EmpserviceIml类中

public class EmpServiceImpl extends ServiceImpl<IEmpDao, Emp> implements IEmpService {
    @Autowired
    IEmpDao empDao;//这里报红没事
    @Override
    public IPage<Emp> queryEmps(IPage<Emp> result, QueryWrapper<Emp> wrapper) {
        result = empDao.queryEmps(result, wrapper);
        return result;
    }
}

8.接下来就是你自己在controller层写方法

示例:

@RequestMapping("qemps")
IPage<Emp> queryEmps(@RequestParam(defaultValue = "1") int page,
                     @RequestParam(defaultValue = "5") int  limit){
    IPage<Emp> result = new Page<>(page, limit);
    QueryWrapper<Emp> wrapper = new QueryWrapper<>();
    wrapper.gt("sal", 1000);//查询条件,工资大于1000,其他的可以研究一下,比如eq,le,like
    return empService.queryEmps(result, wrapper);
}

以上就是多表关联查询了~~~

到此这篇关于Mybatis-Plus多表关联查询的使用案例解析的文章就介绍到这了,更多相关Mybatis-Plus多表关联查询内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯