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);
}
最后效果如下
功能就成功实现啦。
2.添加员工,首先根据前端提交的数据创建EmployeeDTO类用于接收前端数据
前端提交的数据如图所示,根据该图创建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.修改员工信息
首先修改功能要有回显效果,故我们可以根据员工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改为简单数字。
这样就可以做到回显了,页面如下
其次我们要完成修改功能操作,同样是在控制层完成相应接口,代码如下
/**
* 修改员工信息
* @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);
}
最终页面效果如下
注意: 这些功能均采用mybatis-plus实现,要确定已导入坐标依赖,其次根据id查询员工信息时要注意是否存在精度丢失的情况