当前位置: 首页 > news >正文

权威发布新冠用药网络优化工程师简历

权威发布新冠用药,网络优化工程师简历,linux下wordpress,软件技术专升本考什么新增、员工列表、编辑员工整体代码流程与登录基本一致。 1、新增员工 RestController RequestMapping("/admin/employee")EmployeeController 类中使用了注解 RestController 用于构建 RESTful 风格的 API,其中每个方法的返回值会直接序列化为 JSON 或…

新增、员工列表、编辑员工整体代码流程与登录基本一致。
在这里插入图片描述

1、新增员工

@RestController
@RequestMapping("/admin/employee")

EmployeeController 类中使用了注解 @RestController 用于构建 RESTful 风格的 API,其中每个方法的返回值会直接序列化为 JSON 或 XML 数据并发送给客户端。它负责处理对应的请求并返回相应的视图数据。

使用 @RequestMapping("/admin/employee") 注解来指定该控制器处理的 URL 路径的前缀

在这里插入图片描述

EmployeeServiceImpl 类中处理前端传参,设置默认值等,组装数据结构

在这里插入图片描述
@Mapper注解通常用于标识一个 Java 接口或类是 MyBatis 的映射器(Mapper)。MyBatis 是一个持久层框架,用于将数据库操作与 Java 代码进行映射,简化了数据库访问的过程。

@Mapper注解被应用于EmployeeMapper接口,表明该接口是一个 MyBatis 的映射器。通过在接口中的方法上使用@Select注解,可以定义与数据库操作相关的 SQL 语句。

这样,MyBatis 框架可以自动扫描并创建实现映射器接口的代理对象,实现数据库操作与 Java 代码的映射。

在这里插入图片描述

全局异常处理

定义了一个全局异常处理器exceptionHandler,用于处理SQLIntegrityConstraintViolationException类型的异常。在方法中,首先获取异常信息message,然后检查message中是否包含Duplicate entry字符串。

如果包含,则将message按照空格分割,获取第三个元素作为用户名username,并拼接MessageConstant.ALREADY_EXISTS作为错误信息msg,最后返回Result.error(msg)。如果message中不包含Duplicate entry,则返回Result.error(MessageConstant.UNKNOWN_ERROR)

在这里插入图片描述

当用户名重复时触发 sql错误,被全局异常处理器拦截并处理返回处理结果。

使用 swagger 调试
http://localhost:8080/doc.html#/home

在这里插入图片描述

2、员工列表分页查询

@Data
public class EmployeePageQueryDTO implements Serializable {//员工姓名private String name;//页码private int page;//每页显示记录数private int pageSize;
}
/*** 封装分页查询结果*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class PageResult implements Serializable {private long total; //总记录数private List records; //当前页数据集合
}

在这里插入图片描述
PageHelper.startPage 是一个用于分页查询的方法,通常在 MyBatis 框架中与 PageHelper 插件一起使用。

该方法用于设置分页查询的参数,包括当前页码和每页显示的记录数。需要在执行数据库查询之前调用该方法,将分页参数传递进去。

在这里插入图片描述

正确引入了PageHelper分页插件的依赖

在这里插入图片描述
mybatis: mapper-locations用于将配置路径下的 XML 文件加载到 MyBatis 中。

在这里插入图片描述
这是一个 MyBatis 的 Mapper 映射文件的一部分,用于定义数据库操作的 SQL 语句。

<where>:表示查询条件的开始。
<if test="name!= null and name!= ''">
一个条件判断,用于检查参数 name 是否不为空且不为空字符串。如果满足条件,则执行以下的 SQL 片段。
and name like concat('%',#{name},'%')
一个模糊查询条件,用于在 name 列中查找包含指定参数 name 的记录。concat('%',#{name},'%') 会将 % 符号与参数 name 拼接起来,形成一个模糊匹配的模式。

在这里插入图片描述

3、编辑员工与修改账号状态

EmployeeController.java

/*** 启用禁用员工账号* @param status* @param id* @return*/
@PostMapping("/status/{status}")
@ApiOperation("启用禁用员工账号")
public Result startOrStop(@PathVariable Integer status,Long id){log.info("启用禁用员工账号:{},{}",status,id);employeeService.startOrStop(status,id);return Result.success();
}
/*** 编辑员工信息* @param employeeDTO* @return*/
@PutMapping
@ApiOperation("编辑员工信息")
public Result update(@RequestBody EmployeeDTO employeeDTO){log.info("编辑员工信息:{}", employeeDTO);employeeService.update(employeeDTO);return Result.success();
}

EmployeeServiceImpl.java

/*** 启用禁用员工账号** @param status* @param id*/
public void startOrStop(Integer status, Long id) {// update employee set status = ? where id = ?Employee employee = Employee.builder().status(status).id(id).build();employeeMapper.update(employee);
}
/*** 编辑员工信息** @param employeeDTO*/
public void update(EmployeeDTO employeeDTO) {Employee employee = new Employee();//employee.setUpdateTime(LocalDateTime.now());//employee.setUpdateUser(BaseContext.getCurrentId());// 使用属性拷贝简化赋值操作BeanUtils.copyProperties(employeeDTO, employee);employeeMapper.update(employee);
}

EmployeeMapper.java

/*** 根据主键动态修改属性* @param employee*/
@AutoFill(value = OperationType.UPDATE)
void update(Employee employee);

EmployeeMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.sky.mapper.EmployeeMapper"><update id="update" parameterType="Employee">update employee<set><if test="name != null">name = #{name},</if><if test="username != null">username = #{username},</if><if test="password != null">password = #{password},</if><if test="phone != null">phone = #{phone},</if><if test="sex != null">sex = #{sex},</if><if test="idNumber != null">id_Number = #{idNumber},</if><if test="updateTime != null">update_Time = #{updateTime},</if><if test="updateUser != null">update_User = #{updateUser},</if><if test="status != null">status = #{status},</if></set>where id = #{id}</update>
</mapper>

4、实现效果

在这里插入图片描述

5、项目源码

前后端源码及数据库 SQL 文件
https://download.csdn.net/download/qq_44721831/89463416

http://www.yayakq.cn/news/738587/

相关文章:

  • 纯文本网站连接大连网站的优化
  • 手机网站推荐几个当今做那些网站致富
  • 网站建设设计作业哈尔滨网络公司案例
  • 网深圳网站优化品牌营销的基础是什么
  • 棠下手机网站开发山东移动网站建设
  • 网站结构是什么 怎么做软件工程需要学哪些课程
  • 网站建设电话咨询大气的建筑公司名字
  • 盐城专业做网站较好的公司中国电信网站备案
  • 北京网站优化哪家好山东高端网站建设wang
  • 自助建站工具软件免费微商城小程序
  • 房产网站加盟万网域名解析地址
  • 制作网站的公司办什么营业执照上海高端品牌网站建设
  • 关于新农村网络建设网站wordpress 时间代码
  • 交通建设网站公司管理系统下载
  • 做全网营销型网站建设wordpress主题wpgo
  • 太原谁想做网站施工企业税款缴纳
  • 广州网站设计开发公司微信微网站统计
  • 房地产公司网站 源码长沙优化网站服务
  • cms建站系统 开源图书销售网站网页设计模板
  • 网站上面如何加入视频建设网站带后台管理
  • 开原 铁岭网站建设专业商城网站制作公司
  • 网站建设开发合同模板财务公司
  • 高校校园网站建设项目的要求拼多多采用的是哪种网络营销方式
  • 网站维护 代码做app网站的软件
  • 石家庄网站建设行业公司南通企业网站有哪些
  • 做好直播运营必备的五大能力网页搜索引擎优化技术
  • 神木网站设计公司关键词搜索网站
  • 做外贸的网站有哪些想做电商怎么入手视频
  • 网站导航建设注意广州 网站设计
  • 如何做网站数据分析网站建设立项报告