SpringBoot项目|手把手快速搭建员工管理系统(下)

简介: 快速搭建员工管理系统

4、员工管理页面

4.1、查询全部员工

DAO层
  • 编写EmployeeMapper
package com.bobooy.ems.mapper;

import com.bobooy.ems.pojo.Employee;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;

import java.util.Collection;

/**
 * @author BoBooY
 * @date 2022/9/26 23:23
 */
@Mapper
@Repository
public interface EmployeeMapper {
    //查询全体员工信息
    public Collection<Employee> getAll();
}
  • 编写EmployeeMapper.xml
<?xml version="1.0" encoding="UTF8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.bobooy.ems.mapper.EmployeeMapper">
    <select id="getAll" resultMap="EmployeeDepartment">
        select e.id eid, e.last_Name eName, e.email email, e.gender gender,d.id did,e.birth birth, d.department_name dName
        from employee e
        join department d
        on e.department = d.id
    </select>
    <resultMap id="EmployeeDepartment" type="Employee">
        <result property="id" column="eid"/>
        <result property="lastName" column="eName"/>
        <result property="email" column="email"/>
        <result property="gender" column="gender"/>
        <result property="birth" column="birth"/>
        <association property="department" javaType="Department">
            <result property="id" column="did"/>
            <result property="departmentName" column="dName"/>
        </association>
    </resultMap>
</mapper>
service层
  • 编写EmployeeService

    package com.bobooy.ems.service;
    
    import com.bobooy.ems.mapper.EmployeeMapper;
    import com.bobooy.ems.pojo.Employee;
    import org.springframework.stereotype.Service;
    
    import java.util.Collection;
    
    /**
     * @author BoBooY
     * @date 2022/9/26 23:44
     */
    public interface EmployeeService {
        //查询全体员工信息
        public Collection<Employee> getAll();
    }
    • EmployeeServiceImpl
    package com.bobooy.ems.service;
    
    import com.bobooy.ems.mapper.EmployeeMapper;
    import com.bobooy.ems.pojo.Employee;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    
    import java.util.Collection;
    
    /**
     * @author BoBooY
     * @date 2022/9/26 23:45
     */
    @Service
    public class EmployeeServiceImpl implements EmployeeService{
        @Override
        public Collection<Employee> getAll() {
            return employeeMapper.getAll();
        }
    }
    controller层
    • 编写EmployeeContoller
    package com.bobooy.ems.controller;
    
    import com.bobooy.ems.mapper.EmployeeMapper;
    import com.bobooy.ems.pojo.Employee;
    import com.bobooy.ems.service.EmployeeService;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Controller;
    import org.springframework.ui.Model;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RequestMapping;
    
    import java.util.Collection;
    
    /**
     * @author BoBooY
     * @date 2022/9/26 23:20
     */
    @Controller
    public class EmployeeController {
        @Autowired
        private EmployeeService employeeService;
    
        @RequestMapping("/emps")
        public String list(Model model) {
            Collection<Employee> employees = employeeService.getAll();
            model.addAttribute("emps",employees);
            return "emp/list";
        }
    }
    测试

在这里插入图片描述

4.2、添加员工

4.2.1、跳转添加页面

DAO层
  • 编写 DepartmentMapper
package com.bobooy.ems.mapper;

import com.bobooy.ems.pojo.Department;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;

import java.util.Collection;

/**
 * @author BoBooY
 * @date 2022/9/27 0:01
 */
@Mapper
@Repository
public interface DepartmentMapper {
    //获取所有部门的信息
    Collection<Department> getDepartments();

    // 通过ID查询部门
    Department getDepartmentById(Integer id);
}
  • DepartmentMapper.xml
<?xml version="1.0" encoding="UTF8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.bobooy.ems.mapper.DepartmentMapper">
    <select id="getDepartments" resultType="Department">
        select * from department
    </select>

    <select id="getDepartmentById" resultType="Department" parameterType="Integer">
        select * from department where id = #{id}
    </select>
</mapper>
  • 在 application.yaml中开启 Myabtis 驼峰命名映射 注意空格
  configuration:
    map-underscore-to-camel-case: true #开启驼峰命名
Service层
  • DepartmentService
package com.bobooy.ems.service;

import com.bobooy.ems.pojo.Department;

import java.util.Collection;

/**
 * @author BoBooY
 * @date 2022/10/2 10:31
 */
public interface DepartmentService {
    //获取所有部门的信息
    Collection<Department> getDepartments();

    // 通过ID查询部门
    Department getDepartmentById(Integer id);
}
  • DepartmentServiceImpl
package com.bobooy.ems.service;

import com.bobooy.ems.mapper.DepartmentMapper;
import com.bobooy.ems.pojo.Department;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.Collection;

/**
 * @author BoBooY
 * @date 2022/10/2 10:32
 */
@Service
public class DepartmentServiceImpl implements DepartmentService{
    @Autowired
    private DepartmentMapper departmentMapper;

    @Override
    public Collection<Department> getDepartments() {
        return departmentMapper.getDepartments();
    }

    @Override
    public Department getDepartmentById(Integer id) {
        return departmentMapper.getDepartmentById(id);
    }
}
Controller层
  • 在EmployeeController中处理 ”/add“请求
@Autowired
private DepartmentService departmentService;    
@GetMapping("/add")
public String add(Model model) {
    Collection<Department> departments = departmentService.getDepartments();
    model.addAttribute("depts",departments);
    System.out.println(departments);
    return "emp/add";
}
测试

在这里插入图片描述

4.2.2、处理添加员工请求

DAO层
  • 编写EmployeeMapper
//添加员工
public int save(Employee employee);
  • EmployeeMapper.xml
<insert id="save" parameterType="Employee">
    insert into employee(`last_name`, `email`, `gender`, `department`, `birth`)
    values (#{lastName}, #{email}, #{gender}, #{department.id}, #{birth})
</insert>
service层
  • EmployeeService
//添加员工
public int save(Employee employee);
  • EmployeeServiceImpl
@Override
public int save(Employee employee) {
    return employeeMapper.save(employee);
}
controller层
  • EmployeeController
//添加员工
@RequestMapping("/addEmp")
public String addEmp(Employee employee) {
    int save = employeeService.save(employee);
    if(save > 0) {
        System.out.println("添加成功!");
    } else {
        System.out.println("添加失败!");
    }
    return "redirect:/emps";
}
设置日期格式
  • application.yaml(注意空格)
  #日期格式配置
  mvc:
    format:
      date: yyyy-MM-dd HH:mm
测试:添加员工

在这里插入图片描述

在这里插入图片描述

成功!

4.3、修改员工

Dao层
  • 编写 EmployeeMapper
//修改员工
public int updateEmployee(Employee employee);

// 通过ID查询员工
public Employee getEmployee(Integer id);
  • EmployeeMapper.xml
<select id="getEmployee" parameterType="int" resultMap="EmployeeDepartment">
    select e.id eid, e.last_Name eName, e.email email, e.gender gender,d.id did,e.birth birth, d.department_name dName
    from employee e
    join department d
    on e.department = d.id
    where e.id = #{id}
</select>

<update id="updateEmployee" parameterType="Employee">
    update employee set `last_name`=#{lastName},`email`=#{email},`gender`=#{gender},`department`=#{department.id},`birth`=#{birth} where `id` = #{id}
</update>
service层
  • EmployeeService
// 通过ID查询员工
public Employee getEmployee(Integer id);

//修改员工
public int updateEmployee(Employee employee);
  • EmployeeServiceImpl
@Override
public Employee getEmployee(Integer id) {
    return employeeMapper.getEmployee(id);
}

@Override
public int updateEmployee(Employee employee) {
    return employeeMapper.updateEmployee(employee);
}
Controller层
  • EmployeeController
//跳转修改页面
@GetMapping("/update/{id}")
public String update(@PathVariable("id") int id,Model model) {
    Employee employee = employeeService.getEmployee(id);
    model.addAttribute("emp",employee);
    Collection<Department> departments = departmentService.getDepartments();
    model.addAttribute("departments",departments);
    return "emp/update";
}

//修改员工信息
@PostMapping("/updateEmp")
public String update(Employee employee) {
    int update = employeeService.updateEmployee(employee);
    if(update > 0) {
        System.out.println("修改成功");
    }else {
        System.out.println("修改失败");
    }
    return "redirect:/emps";
}
测试:修改id为 1012 的员工部门为 后勤部 性别为男
  • 修改前:

在这里插入图片描述

  • 修改页面:

在这里插入图片描述

  • 修改后:

在这里插入图片描述

成功!

4.4、删除员工

Dao层
  • EmployeeMapper
// 删除员工
public int delete(Integer id);
  • EmployeeMapper.xml
<delete id="delete" parameterType="int">
    delete from employee where `id` = #{id}
</delete>
service层
  • EmployeeService
// 删除员工
public int delete(Integer id);
  • EmployeeServiceImpl
@Override
public int delete(Integer id) {
    return employeeMapper.delete(id);
}
controller层
  • EmployeeController
//删除员工
@RequestMapping("/delete/{id}")
public String delete(@PathVariable("id") int id) {
    int delete = employeeService.delete(id);
    if(delete > 0)
        System.out.println("删除成功!");
    else {
        System.out.println("删除失败!");
    }
    return "redirect:/emps";
}
测试:删除id为1011的员工
  • 删除前

在这里插入图片描述

  • 删除后

在这里插入图片描述

5、退出登录

  • UserController
//退出登录
@RequestMapping("/logout")
public String logout(HttpSession session) {
    session.invalidate(); //使当前session失效
    return "redirect:/index.html";
}
  • 测试:退出后 直接访问登录页面

在这里插入图片描述

目录
相关文章
|
28天前
|
XML Java 应用服务中间件
SpringBoot项目打war包流程
本文介绍了将Spring Boot项目改造为WAR包并部署到外部Tomcat服务器的步骤。主要内容包括:1) 修改pom.xml中的打包方式为WAR;2) 排除Spring Boot内置的Tomcat依赖;3) 添加Servlet API依赖;4) 改造启动类以支持WAR部署;5) 打包和部署。通过这些步骤,可以轻松地将Spring Boot应用转换为适合外部Tomcat服务器的WAR包。
132 64
SpringBoot项目打war包流程
|
1月前
基于springboot+thymeleaf+Redis仿知乎网站问答项目源码
基于springboot+thymeleaf+Redis仿知乎网站问答项目源码
136 36
|
28天前
|
前端开发 JavaScript Java
springboot图书馆管理系统前后端分离版本
springboot图书馆管理系统前后端分离版本
39 12
|
23天前
|
自然语言处理 IDE Java
SpringBoot start.aliyun.com创建项目,解决properties乱码的问题
通过确保文件和开发环境的编码一致,配置 Maven 编码,设置 Spring Boot 应用和嵌入式服务器的编码,可以有效解决 properties 文件的乱码问题。以上步骤可以帮助开发者确保在 Spring Boot 项目中正确处理和显示多语言字符,避免因编码问题导致的乱码现象。
36 5
|
26天前
|
JavaScript NoSQL Java
基于SpringBoot+Vue实现的大学生就业服务平台设计与实现(系统源码+文档+数据库+部署等)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
67 6
|
26天前
|
JavaScript Java 测试技术
基于Java+SpringBoot+Vue实现的车辆充电桩系统设计与实现(系统源码+文档+部署讲解等)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
57 6
|
26天前
|
JavaScript NoSQL Java
基于SpringBoot+Vue的班级综合测评管理系统设计与实现(系统源码+文档+数据库+部署等)
✌免费选题、功能需求设计、任务书、开题报告、中期检查、程序功能实现、论文辅导、论文降重、答辩PPT辅导、会议视频一对一讲解代码等✌
40 4
|
26天前
|
JavaScript NoSQL Java
基于SpringBoot+Vue实现的大学生体质测试管理系统设计与实现(系统源码+文档+数据库+部署)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
38 2
|
1月前
|
存储 安全 Java
Spring Boot 3 集成Spring AOP实现系统日志记录
本文介绍了如何在Spring Boot 3中集成Spring AOP实现系统日志记录功能。通过定义`SysLog`注解和配置相应的AOP切面,可以在方法执行前后自动记录日志信息,包括操作的开始时间、结束时间、请求参数、返回结果、异常信息等,并将这些信息保存到数据库中。此外,还使用了`ThreadLocal`变量来存储每个线程独立的日志数据,确保线程安全。文中还展示了项目实战中的部分代码片段,以及基于Spring Boot 3 + Vue 3构建的快速开发框架的简介与内置功能列表。此框架结合了当前主流技术栈,提供了用户管理、权限控制、接口文档自动生成等多项实用特性。
84 8
|
26天前
|
JavaScript NoSQL Java
基于SpringBoot+Vue实现的冬奥会科普平台设计与实现(系统源码+文档+数据库+部署)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
45 0