苍穹外卖编辑员工信息

1.员工启用禁用功能                                                                                                                           

控制层通过id来查询员工信息,这里注意数据库中id是long型,长度有18位,很可能出现精度丢失查询不到的情况,这里就要自己去将id改为string类型来查询或者自己手动去数据库修改id为简单数字。

控制层代码如下

@GetMapping("/{id}")
    public Result getById(@PathVariable Integer id) {
        Employee employee = employeeService.getById(id);
        return Result.success(employee);
    }

业务层代码

public void startOrStop(Integer status, Long id) {
        LambdaQueryWrapper qw = new LambdaQueryWrapper<>();//查询条件构造器
        //根据前端传过来的id获取员工数据
        qw.eq(Employee::getId, id);
        Employee employee = employeeMapper.selectOne(qw);
        //修改用户状态
        employee.setStatus(status);
        //根据mybatis-plus提供的方法修改员工状态,注意这是BaseMapper提供的方法
        employeeMapper.update(employee, qw);
    }

最后效果如下

苍穹外卖编辑员工信息_第1张图片

 功能就成功实现啦。

2.添加员工,首先根据前端提交的数据创建EmployeeDTO类用于接收前端数据                               苍穹外卖编辑员工信息_第2张图片

 前端提交的数据如图所示,根据该图创建dto,存在一一对应关系

@Data
public class EmployeeDTO implements Serializable {

    private Long id;

    private String username;

    private String name;

    private String phone;

    private String sex;

    private String idNumber;

}

接着在控制层实现对应接口

/**
     * 新增员工
     * @param employeeDTO
     * @return
     */
    @PostMapping
    public Result save(@RequestBody EmployeeDTO employeeDTO) {
        log.info("新增员工:{}",employeeDTO);
        employeeService.save(employeeDTO);
        return Result.success();
    }

对应save方法在业务层去实现,首先将前端传过来的数据用dto来接收,再将dto拷贝到Employee类(对应数据库中的员工表)中。由于employee其他属性还未接收(只有由前端传过来的数据),故其他数据要后端根据set方法手动添加。最后根据mybatis-plus提供的方法进行插入操作。

    @Override
    public void save(EmployeeDTO employeeDTO) {
        Employee employee = new Employee();

        //对象属性拷贝
        BeanUtils.copyProperties(employeeDTO, employee);
        //设置状态
        employee.setStatus(StatusConstant.ENABLE);
        //设置密码
        employee.setPassword(DigestUtils.md5DigestAsHex(PasswordConstant.DEFAULT_PASSWORD.getBytes()));
        //设置创建时间
        employee.setCreateTime(LocalDateTime.now());
        employee.setUpdateTime(LocalDateTime.now());
        //设置当前记录创建人的id

        employee.setCreateUser(BaseContext.getCurrentId());
        employee.setUpdateUser(BaseContext.getCurrentId());

        employeeMapper.insert(employee);//由mybatuis-plus提供的方法
    }

其中使用mybatis-plus技术首先要在pom文件中导入坐标依赖


    com.baomidou
    mybatis-plus-boot-starter
    3.4.2

然后要在Mapper中继承BaseMapper才可使用insert方法。

@Mapper
public interface EmployeeMapper extends BaseMapper{

}

最终功能效果如下

苍穹外卖编辑员工信息_第3张图片

苍穹外卖编辑员工信息_第4张图片

3.修改员工信息

首先修改功能要有回显效果,故我们可以根据员工id进行查询

首先控制层代码如下,该功能与启用禁用员工进行id查询采用的接口一致

@GetMapping("/{id}")
    public Result getById(@PathVariable Integer id) {
        Employee employee = employeeService.getById(id);
        return Result.success(employee);
    }

 根据id来查询的功能我们在业务层去实现

    public Employee getById(Integer id) {

        LambdaQueryWrapper qw = new LambdaQueryWrapper<>();

        qw.eq(Employee::getId, id);
        Employee employee = employeeMapper.selectOne(qw);
        //将密码以****形式提交,自己选择
        //employee.setPassword("****");
        //返回员工信息给控制层
        return employee;
    }

这里注意我们在添加员工时生成的id是18位,用Long型去接收会造成精度丢失,我们可以将Long型改成字符串型(比较麻烦),为了方便测试也可以直接在数据库中将id改为简单数字。

这样就可以做到回显了,页面如下

苍穹外卖编辑员工信息_第5张图片

其次我们要完成修改功能操作,同样是在控制层完成相应接口,代码如下

/**
     * 修改员工信息
     * @param employeeDTO
     * @return
     */
    @PutMapping   
    public Result update(@RequestBody EmployeeDTO employeeDTO)
    {
        log.info("编辑员工信息:{}",employeeDTO);
        employeeService.update(employeeDTO);
        return Result.success();
    }

 更新操作同样放在业务层去实现

public void update(EmployeeDTO employeeDTO) {
        //创建一个employee用于接收前端传过来的数据
        Employee employee = new Employee();
        //前端传过来的数据是用employeeDTO来封装的,因此我们要将DTO数据拷贝到employee中
        BeanUtils.copyProperties(employeeDTO,employee);
        //创建条件查询构造器,根据id确定要修改的员工信息
        LambdaQueryWrapper qw = new LambdaQueryWrapper<>();
        qw.eq(Employee::getId, employeeDTO.getId());
        //将DTO中没有的数据手动赋值
        employee.setUpdateTime(LocalDateTime.now());
        employee.setUpdateUser(BaseContext.getCurrentId());
        //根据mybatis-plus提供的方法将员工信息以及查询条件传进去进行数据库跟新操作
        employeeMapper.update(employee, qw);
    }

最终页面效果如下

苍穹外卖编辑员工信息_第6张图片

苍穹外卖编辑员工信息_第7张图片

注意: 这些功能均采用mybatis-plus实现,要确定已导入坐标依赖,其次根据id查询员工信息时要注意是否存在精度丢失的情况

你可能感兴趣的:(状态模式,java,spring,boot,mybatis)