【Day10】springboot 综合案例 部门管理 员工管理

2024-04-28 00:12

本文主要是介绍【Day10】springboot 综合案例 部门管理 员工管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 综合案例《tlias 智能学习辅助系统》

1 准备工作

1.1 数据库建表

1.2 项目结构

1.3 pom.XML 配置依赖

1.4 application.properties 配置

包括数据库,camel,日志

1.5 接口文档 

 

1.6 (番外篇)springboot 三层架构

只有理解了三层架构才能更好地开发

springboot 的三层架构:

  • controller 层
  • service 层
  • dao 层

1.6.1 controller 层

        controller 层叫控制器层

        负责前后端交互,接受前端请求,调用service层,接收service层返回的数据,最后返回具体的页面和数据到客户端

1.6.2 service 层

        service 层叫业务逻辑层

        存放业务逻辑处理,不直接对数据库进行操作,有接口和接口实现类,提供 controller 层调用的方法

        创建两个文件,一个存放接口类,一个存放接口实现类        

1.6.3 dao 层

        dao层也叫 mapper 层数据访问层
        对数据库进行持久化操作,他的方法是针对数据库操作的,基本用到的就是增删改查。它只是个接口,只有方法名字,具体实现在 mapper.xml 中

       

1.6.4 model 层

        model 层也叫 pojo 层或者 entity 层,一般数据库的一张表对应一个pojo层,并且表中所有字段都在pojo层都一一对应

2 开发规范

2.1 RESTful

RESTful(REpresentational State Transfer),表述性状态转换,一种软件架构风格

HTTP动词:增、删、改、查

对应四种不同的请求:

  • GET 查询
  • POST 新增
  • PUT 修改
  • DELETE 删除

        描述模块的功能通常使用复数,也就是加 s 的格式来描述,表示此类资源,而非单个资源。如:users、emps、books...

2.2 统一响应结果

把 Result 类放入 pojo 下

3 开发-部门管理(有一个待解决问题)

3.1 部门列表查询(有一个待解决问题)

3.1.1 查看接口文档

  • 基本信息

  • 请求参数

        无

  • 响应数据(Result 类格式)

3.1.2 思路

前端发来请求

        controller 层进行接收,调用下一层的 service 层

        service 层无法直接操作数据库,只有  dao层(数据访问层)才可以。所以 service 层继续

调用 dao 层

        dao 层(mapper层)对数据库进行访问操作,然后返回

        最后又 controller 层响应回前端

3.1.3 实现

在 debug 时,经常用到日志

private static Logger log = LoggerFactory.getLogger(DeptController.class);
log.info("查询全部部门数据");

 其实可以用注解 @slf4j 简化:

在前面方法加上注解,就可以直接用 log 日志对象了

第一步:controller 层

Result pojo 对象是这样的:

对 success 方法进行了重载(overloading)

第二步,service 层

我们去 DeptService 接口,定义这个方法

然后我们再去 Impl 类文件里面去具体实现

        由于 service 层还是无法直接操作数据库,我们接着往下调用去 dao 层(Mapper层),还是通过注入 dao 层对象调用这个对象的方法

第三步,dao 层(Mapper 层)

        这里面只有接口(interface),直接写注解,写查询语句,剩下的交给 springboot

3.1.4 测试

运行入口文件,springboot 自动启动 tomcat,占用端口 8080

使用 postman 发送规定的 GET 请求:

得到数据结果

发送 POST 请求则报错

3.1.5 前后端联调(有一个待解决问题)

刚才的测试是用 tomcat 在后端测试,接下来的测试需要在前端发请求


这里有一个待解决的问题

使用自己写的 vue 前端页面,用 axios 做异步请求,能从

mock.apifox.cn/m1/3128855-0-default/emp/list

上面获取数据

但是从本机的

localhost:8080/depts

就不行,挂在 Nginx 服务器上显示“暂无数据”

每次进行访问,比如刷新页面和点击“部门管理”,在 IDEA 控制台都有响应

 他们都是 JOSN 格式,区别在于 URL

 

 已经尝试了很长时间,未果

于是,使用了课程资料的 nginx

里面自带了 dist(vue 脚手架打包之后的文件放在这里,启动 nginx,看到的页面就是这个)

居然能成功,怀疑是配置文件的问题,以后再说,因为现在根本看不懂这么复杂的代码


3.1.6 nginx 关闭的三种方法

  • nginx -s stop

  • nginx -s quit

  • taskkill /F /IM nginx.exe > nul

3.2 删除部门

3.2.1 查看文档

3.2.2 实现

 

测试:

成功删除

3.3 新增部门

3.3.1 查看文档

3.3.2 思路

        注意 service 层要补充基础属性,因为前端发来 post 请求,里面只有参数 name,而我们要插入数据库的时候,要补充字段 create_time 和 update_time,这部分的操作在 service 层

3.3.3 实现

第一步,controller 层接受请求,并调用 service

使用注解是 @PostMapping 里面写文档要求的 depts

按照 POST 方式接收请求,是一个在 消息体 中的 JSON 文件,格式是:

{"name":"就业部"
}

使用注解 @RequestBody

这样就把传递过来的 JSON 文件自动包装成一个 Dept 对象

第二步

比较经典的 service 接口、service 实现

要注意的是,在实现类里面,要补充字段

        因为传递过来的 JSON 里面只有 name,而实际上 dept 数据库表有四个字段:id、name、create_time、update_time。

        id 是设置成自增,不用管,但是还有两个时间字段,这时候就需要自己进行添加了,而之所以在 service 层添加,是因为 service 是 业务逻辑层 ,而下一层 dao 是 数据访问层,dao 直接进行操作而不是补充字段

 

 

第三步

(这里把右上角的数据库改了,现在不用加 tlias 前缀)

 

3.3.4 测试

 

3.4 controller 层注解简化

Mapping 既然都有公共字段,那就直接在前面抽取

 

3.5 (自己写)修改部门

没有演示,那就自己写吧

先阅读文档

请求参数样例:

{"id": 1,"name": "教研部"
}

第一步

在前面先加上

@RequestMapping("/depts")

        同时要注意看文档,请求的方式是 PUT,之前我写成 POST ,和上面新增部门的方法请求方式相同了,springboot 报了错

第二步

 第三步

之前我用的是

@Update("update dept set name = dept.name where id = dept.id")

 这样并不能成功

        原因是必须使用 mybatis 的动态 SQL,使用 #{} 的占位符,而上面写的,仅仅是字符串,相当于判断 id 为 'dept.id' 的字段,这显然是没有这个字段的

测试

 4 开发-员工管理

员工管理更复杂,原因是需要 分页查询 

4.1 基础分页查询

首先回顾 MySQL 分页查询

注意看下面,用户可以设置每页展示的数据条数,当前页码,还有一共多少条数据

 

 4.1.1 文档

 响应数据

{
"code": 1,
"msg": "success",
"data": {
"total": 2,
"rows": [
{
"id": 1,
"username": "jinyong",
"password": "123456",
"name": "金庸",
"gender": 1,
"image": "https://web-framework.oss-cnhangzhou.aliyuncs.com/2022-09-02-00-27-53B.jpg",
"job": 2,
"entrydate": "2015-01-01",
"deptId": 2,
"createTime": "2022-09-01T23:06:30",
"updateTime": "2022-09-02T00:29:04"
},
{
"id": 2,
"username": "zhangwuji",
"password": "123456",
"name": "张无忌",
"gender": 1,
"image": "https://web-framework.oss-cnhangzhou.aliyuncs.com/2022-09-02-00-27-53B.jpg",
"job": 2,
"entrydate": "2015-01-01",
"deptId": 2,
"createTime": "2022-09-01T23:06:30",
"updateTime": "2022-09-02T00:29:04"
}
]
}
}

4.1.2 思路

 

4.1.3 实现

上面提到了一个 实体类 PageBean,里面装的是关于分页的数据,把它放在 pojo 里面

 字段的命名,都是根据 文档 来的

 

 第一步,根据分析,在数据库需要两次查询,我们先写操作数据库的 dao 层

一个查总数据条数

一个查分页,分页查询返回的是 List<Emp>

 第二步

 文档要求要有默认值,我们可以加上 if 判断,如果为 null,我们就给值

但是这样太麻烦,所以我们使用注解

@Request(defaultValue = "默认值")

第三步

service 层,还是固定写法,但是注意的是公式

起始索引 = (页码数 - 1)* 一页的大小

 

4.1.4 测试

不输入分页信息,一次展示10条,起始索引 0(id 为1)

 给定了固定的页码信息,我们要看第二页,从 11 开始到 17(因为一共17个)

 

4.2 PageHelper

引入 PageHelper 依赖

 

安装了 PageHelper 插件,我们现在只需要在 Mapper 里面定义一个最基本的查询

 

 然后在 service 实现类中进行固定的操作:

  • 第一步

设置分页参数(这是传过来的两个参数)

第一个参数是当前是第几页

第二个参数是一页几条数据

PageHelper.startPage(page,pageSize);

  • 第二步

执行查询

拿到 emplist,要强制类型转换为 Page 类型,这是个已经定义好的方法

List<Emp> empList = empMapper.list();
Page<Emp> p = (Page<Emp>) empList;

 

然后就可以测试了

启动会有一个很好看的字符画

 然后 postman

id 从 6 到 10,正好是第二页的 5 条

4.3 (自己写出来了)条件分页查询

4.3.1 分析

这是之前学过的 mybatis 的动态 SQL

先复习一下动态 SQL:

        在和 EmpMapper 同包同名的 XML 文件里面写 SQL 语句,并且使用 mybatis 的 <if>标签,在里面进行姓名、性别、入职时间的三项任意动态查询

        然后比较关键的是,不要在里面写 limit ,这是因为,我们要使用刚才用过的 PageHelper插件,这个插件可以基于普通查询自动分页,我们只需要调用接口就可以了

下面讨论的是各个方法之间的传参:

我们要展示的字段有以下这些

        这些字段是从数据库能查到的,只要在 where 里面设置条件就可以。但是条件是从前端通过 GET 请求发过来的,这个请求含有name、gender、begin、end。这些参数需要从 controller 层去传到 dao (mapper)层,再加上我们要分页的两个参数分别是当前页码 page 和 一页数据量pageSize,一共是 6 个传参

4.3.2 实现

  • 第一步 controller 层

在 page 和 pageSize 的基础上,又加了条件查询的 4 个参数

        要注意的是,(看注释)我本来是自己手动去调整 begin 和 end ,一开始是 String 类型,但是,我们用的是 springboot,是一个【框架】,我们不需要自己去手动干活(我这样单纯地 parse 也不太好用,因为里面有一些空指针异常需要额外判断)。所以我们使用了注解

@DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate begin

这样是 springboot 框架自动处理,就不需要我们自己手动处理了

                                                我们要面向注解编程

拿到所有参数,controller 层任务完成,调用下一层——service层

  • 第二步 service 层

service 接口

我们使用了 PageHelper 插件,操作也是比较固定:

1.设置分页参数

PageHelper.startPage(page, pageSize);

        这步要注意,不是 new 一个对象,是使用它内置的静态方法去设置,传递的参数就 page 和 pageSize

2.执行查询

List<Emp> empList  = empMapper.selectCondition(name, gender, begin, end);

Page<Emp> p = (Page<Emp>) empList;

        直接进行条件查询,我们要拿到的是一个基于传参的条件数据 List 表,把这个 List 表强制转换为 PageHelper 插件的 Page 类型

        需要注意的是,向 dao 层传参的时候,就传它需要的查询字段就可以了(我之前把 page 和pageSize 也传了,完全是没必要的)

3.封装 PageBean 对象

我们先回顾一下我们定义的 PageBean 对象:

public class PageBean {private Long total; // 总记录数private List rows; // 当前页 数据列表
}

PageBean pageBean = new PageBean(p.getTotal(), p.getResult());

        我们的最终目的是把这个 PageBean 打包带回给 controller 层,然后到 controller 层再进行包装为 Result 最终返回给前端,所以我们在这里直接调用 PageBean 的 getTotal() 和 getResult() 方法,拿到 数据量 和 经过 PageHelper 分页后的数据 List 表

  • 第三步 dao 层

查询语句比较复杂,我们不用注解,使用了 XML 映射

        XML 映射的要求是同包同名

 然后在每个参数前加上注解

@param("参数名")

接下来在 XML 里面写 SQL 语句

这是之前写过的,比较简单

 写完这个就完成了

4.3.3 测试

发起 GET 请求,查出一个人

其他的也都类似,不再进行重复演示

4.4 批量删除员工

比较简单,所以就直接实现了

第一步

第二步 

接口省略了

第三步

4.5 新增员工

  • 第一步

        要特别注意的是,使用 POST 方法,在方法体中传递 JSON 数据,这个时候需要注解

@RequestBody

这样就把 JSON 格式的数据包装到后面指定的对象当中

  • 第二步

 

  • 第三步

在 Mapper 层用 XML 映射

测试

这篇关于【Day10】springboot 综合案例 部门管理 员工管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/941870

相关文章

Java五子棋之坐标校正

上篇针对了Java项目中的解构思维,在这篇内容中我们不妨从整体项目中拆解拿出一个非常重要的五子棋逻辑实现:坐标校正,我们如何使漫无目的鼠标点击变得有序化和可控化呢? 目录 一、从鼠标监听到获取坐标 1.MouseListener和MouseAdapter 2.mousePressed方法 二、坐标校正的具体实现方法 1.关于fillOval方法 2.坐标获取 3.坐标转换 4.坐

Spring Cloud:构建分布式系统的利器

引言 在当今的云计算和微服务架构时代,构建高效、可靠的分布式系统成为软件开发的重要任务。Spring Cloud 提供了一套完整的解决方案,帮助开发者快速构建分布式系统中的一些常见模式(例如配置管理、服务发现、断路器等)。本文将探讨 Spring Cloud 的定义、核心组件、应用场景以及未来的发展趋势。 什么是 Spring Cloud Spring Cloud 是一个基于 Spring

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

java8的新特性之一(Java Lambda表达式)

1:Java8的新特性 Lambda 表达式: 允许以更简洁的方式表示匿名函数(或称为闭包)。可以将Lambda表达式作为参数传递给方法或赋值给函数式接口类型的变量。 Stream API: 提供了一种处理集合数据的流式处理方式,支持函数式编程风格。 允许以声明性方式处理数据集合(如List、Set等)。提供了一系列操作,如map、filter、reduce等,以支持复杂的查询和转

用Microsoft.Extensions.Hosting 管理WPF项目.

首先引入必要的包: <ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog

Java面试八股之怎么通过Java程序判断JVM是32位还是64位

怎么通过Java程序判断JVM是32位还是64位 可以通过Java程序内部检查系统属性来判断当前运行的JVM是32位还是64位。以下是一个简单的方法: public class JvmBitCheck {public static void main(String[] args) {String arch = System.getProperty("os.arch");String dataM

详细分析Springmvc中的@ModelAttribute基本知识(附Demo)

目录 前言1. 注解用法1.1 方法参数1.2 方法1.3 类 2. 注解场景2.1 表单参数2.2 AJAX请求2.3 文件上传 3. 实战4. 总结 前言 将请求参数绑定到模型对象上,或者在请求处理之前添加模型属性 可以在方法参数、方法或者类上使用 一般适用这几种场景: 表单处理:通过 @ModelAttribute 将表单数据绑定到模型对象上预处理逻辑:在请求处理之前

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

JAVA读取MongoDB中的二进制图片并显示在页面上

1:Jsp页面: <td><img src="${ctx}/mongoImg/show"></td> 2:xml配置: <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001

Java面试题:通过实例说明内连接、左外连接和右外连接的区别

在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。 表示例 假设有两个表:Customers 和 Orders。 Customers CustomerIDCus