tlias智能学习辅助系统-增删改查+参数传递

news2025/1/16 4:58:37

  本篇实现黑马tlias智能学习辅助系统中的部门以及员工管理,主要完成增删改查操作以及一些细节问题,后面会进一步总结登录校验、异常处理以及AOP的内容。


目录

一、环境搭建:

二、部门管理: 

1、查询所有部门:

controller层代码:

Service层中的代码:

Mapper层中的代码:

2、删除部门:

Controller层中代码:

Service层中代码:

Mapper层中代码:

3、添加部门:

Controller层中的代码:

Service层中的代码:

Mapper层中的代码:

4、修改部门:

Controller层中的代码:

Service层中的代码:

Mapper层中的代码:

三、员工管理

1、分页查询所有员工:

Controller层中的代码:

Service层中的代码:

Mapper层中的代码:

xml映射文件中的sql语句:

2、批量删除操作:

Controller层中的代码:

Service层中的代码:

Mapper层中的代码:

xml映射文件中的SQL语句:

3、新增员工:

Controller层中的代码:

Service层中的代码:

Mapper层中的代码:

4、修改员工信息:

Controller层中的代码:

Service层中的代码:

Mapper层中的代码:

xml映射文件中的SQL语句:


一、环境搭建:

  • 准备数据库表(dept、emp)
  • 创建springboot工程,引入对应的起步依赖(web、mybatis、lombok、mysql驱动)
  • 配置application.properties文件,引入mybatis配置信息,准备实体类
  • 准备Mapper、Service接口以及实现类,Controller层代码
  • 依然使用前面讲过的统一响应结果Result。

整体的代码结构如下:

整体的开发流程如下:

二、部门管理: 

1、查询所有部门:

controller层代码:

输出日志:引入Slf4j包下的logger。

直接使用GetMappring指定为get请求。

由于增删改查功能中请求路径中都包含/depts,因此使用@RequestMapping注解,放在类的前面,简化操作。因此完整的请求路径就是类上的@RequestMapping的value属性+方法上的@RequestMappring的value属性

@RestController
@Slf4j
@RequestMapping("/depts")//在前面加上后,下面的就可以注释掉了,不用加depts了
public class DeptController {
    @Autowired
    private DeptService deptService;

    //TODO 查询所有部门数据:
    //private static Logger log= LoggerFactory.getLogger(DeptController.class);//引入slf4j包下的 这段代码是固定的,所以为了方便起见,可以直接添加一个注解:slf4j
    //@RequestMapping(value = "/depts",method = RequestMethod.GET)//指定请求方式是get,但是有一种更简洁的方式如下;
    //@GetMapping("/depts")//在postman中测试用post请求会报405
    @GetMapping
    public Result list(){
        log.info("查询全部信息");//一般不用sout输出,正规一些要用logback日志的形式输出;

        List<Dept> deptList=deptService.list();
        return Result.success(deptList);
    }
Service层中的代码:
@Override
    public List<Dept> list() {
        return deptMapper.list();
    }
Mapper层中的代码:
@Mapper
public interface DeptMapper {
    @Select("select *from dept")//因为查询语句很简单,不用xml映射文件中配置的方法;
    List<Dept> list();

2、删除部门:

Controller层中代码:
//TODO 删除指定部门:
    //@DeleteMapping("/depts/{id}")
    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Integer id){//PathBariable注解将路径中的id绑定到参数id;
        log.info("根据参数id删除部门:{}",id);
        deptService.delete(id);
        return Result.success();
    }
Service层中代码:
public void deleteById(Integer id){
    deptMapper.deleteById(id);
}
Mapper层中代码:
@Delete("delete from dept where id=#{id}")
    void delete(Integer id);

3、添加部门:

Controller层中的代码:

要使用@RequestBody注解将前端发送的json格式数据封装到实体类对象当中

//TODO 添加部门:
    //@PostMapping("/depts")
    @PostMapping
    public Result add(@RequestBody Dept dept){
        log.info("添加部门:{}",dept);
        deptService.add(dept);
        return Result.success();
    }
Service层中的代码:

注意此处需要将创建时间以及更新时间两个属性定义好,前端界面添加面板中没有这两个属性。

@Override
    public void add(Dept dept) {
        dept.setCreateTime(LocalDateTime.now());
        dept.setUpdateTime(LocalDateTime.now());
        deptMapper.insert(dept);
    }
Mapper层中的代码:
@Insert("insert into dept(name,create_time,update_time) values(#{name},#{createTime},#{updateTime})")
    void insert(Dept dept);

4、修改部门:

Controller层中的代码:

注意修改部门涉及到两个操作,可以看到在前端界面中点击编辑后先是一个get请求,需要先进行一步根据id查询操作,相当于进行一个绑定操作,然后再进行put请求,进行修改操作。

//TODO 修改部门:包含两部分,首先是一个查询get请求,然后将那条数据查询出来然后跟修改绑定到一起,这样id就会对应,后面的set方法也不用设置createTime属性。
    @GetMapping("/{id}")
    public Result getById(@PathVariable Integer id) {
        log.info("获取部门id号:" + id);
        Dept dept = deptService.getById(id);
        return Result.success(dept);
    }
    @PutMapping
    public Result update(@RequestBody Dept dept){
        log.info("修改部门");
        deptService.update(dept);
        return Result.success();

    }
Service层中的代码:
@Override
    public Dept getById(Integer id) {
        return deptMapper.getById(id);

    }
    @Override
    public void update(Dept dept) {
        dept.setUpdateTime(LocalDateTime.now());//此处已经和查询的数据联合起来了,所以不用对createtime进行设置,不会为null;
        deptMapper.update(dept);
Mapper层中的代码:
@Select("select * from dept where id=#{id}")
    Dept getById(Integer id);
    @Update("update dept set name=#{name},create_time=#{createTime},update_time=#{updateTime} where id=#{id} ")
    void update(Dept dept);

三、员工管理

1、分页查询所有员工:

注意查询员工的时候分页查询,前端需要传递两个参数,然后服务端返回两个数据,但是同时返回两个并且还是不同类型的数据,此时可以用map也可以用一个实体类进行封装(PageBean类,包含两个属性一个是Integer类型的记录总数,另一个是集合类型的用于存储Emp实体类对象)。

最重要的是分析出来前端传入什么,服务端返回什么,此处前端传入的是哪一页以及一页最多有多少条数据。而服务端应该返回所有的数据个数以及这一页的数据。

使用分页插件:

条件分页查询(动态sql语句):

注意此处还要加上 and name!=’’,代表name不为空且不为空串的时候才加上这个name条件语句,因为通过前后端联调后发现如果什么都不写的话,name会是一个空串,并不是null。

Controller层中的代码:

使用@RequestParam设置默认值,

 //TODO 条件分页查询(动态sql):其中也包含了查询所有员工
    @GetMapping
    public Result page(@RequestParam(defaultValue = "1")Integer page,//TODO 注意此处的参数名和前端传入的参数名相同就可以自动接收;
                       @RequestParam(defaultValue = "10") Integer pageSize,
                       String name, Short gender,
                       @DateTimeFormat(pattern ="yyyy-MM-dd") LocalDate begin,
                       @DateTimeFormat(pattern ="yyyy-MM-dd") LocalDate end)//此处是设置默认值。利用@RequestParam注解;
    {
        log.info("条件分页查询,参数为:"+page+" "+pageSize+" "+name+" "+gender+" "+begin+" "+end);
        PageBean pageBean=empService.page(page,pageSize,name, gender,   begin,end);
        return Result.success(pageBean);
    }
Service层中的代码:
//TODO 条件分页查询:
    @Override
    public PageBean page(Integer page, Integer pageSize, String name, Short gender, LocalDate begin, LocalDate end){
        //1.设置分页参数:
        PageHelper.startPage(page,pageSize);
        //2.执行查询操作:
        List<Emp> emplist = empMapper.list(name, gender, begin,end);//注意此处调用了list方法其实自动封装成Page类型,所以emplist是Page类型的
        Page<Emp> p=(Page<Emp>)emplist;
        //3.封装为PageBean:
        PageBean pageBean=new PageBean(p.getTotal(),p.getResult());
        return pageBean;
    }
Mapper层中的代码:
//TODO 条件分页查询:注意此处是动态sql,所以要用xml映射文件
    public List<Emp> list(String name, Short gender, LocalDate begin, LocalDate end);
xml映射文件中的sql语句:
 <select id="list" resultType="com.springboot_test.pojo.Emp">
        select * from emp
        <where>
            <if test="name!=null and name!=''">
                name like concat('%',#{name},'%')
            </if>
            <if test="gender!=null">
                and gender=#{gender}
            </if>
            <if test="begin != null and end !=null">
                and entrydate between #{begin} and #{end}
            </if>
        </where>
        order by update_time desc
    </select>

2、批量删除操作:

Controller层中的代码:
 //TODO 批量删除操作:
    @MyLog
    @DeleteMapping("/{ids}")
    public Result delete(@PathVariable List<Integer> ids){
        log.info("批量删除操作ids为"+ids);
        empService.delete(ids);
        return Result.success();
    }
Service层中的代码:
//TODO 批量删除操作:
    public void delete(List<Integer> ids){
        empMapper.delete(ids);
    }
Mapper层中的代码:
//TODO 批量删除操作:
    void delete(List<Integer> ids);//TODO 注意此处的参数名称ids要和xml配置文件中foreach中collection参数的值相同
xml映射文件中的SQL语句:
 <delete id="delete">
        delete from emp where id in
        <foreach collection="ids" item="id" separator="," open="(" close=")">
            #{id}
        </foreach>
    </delete>

3、新增员工:

Controller层中的代码:
//TODO 新增员工:
    @PostMapping
    public Result save(@RequestBody Emp emp){
        log.info("新增员工操作"+emp);
        empService.save(emp);
        return Result.success();
    }
Service层中的代码:
//TODO 新增员工操作:
    public void save(Emp emp){
        emp.setCreateTime(LocalDateTime.now());
        emp.setUpdateTime(LocalDateTime.now());
        empMapper.save(emp);
    }
Mapper层中的代码:
//TODO 新增员工操作:
    @Insert("insert into emp(username, name, " +
            "gender, image,job, " +
            "entrydate, dept_id, create_time," +
            "update_time) values(#{username},#{name},#{gender},#{image},#{job},#{entrydate},#{deptId},#{createTime},#{updateTime})")
    void save(Emp emp);

4、修改员工信息:

注意,此处修改员工信息操作和前面修改部门信息操作类似,需要先进行查询然后将数据联合起来,相当于进行一步绑定操作,将此员工信息显示出来,然后再进行修改。

Controller层中的代码:
//TODO 修改员工:
    @GetMapping("/{id}")
    public Result getById(@PathVariable Integer id){
        log.info("根据id查询员工信息,id为"+id);
        Emp emp1=empService.getById(id);
        return Result.success(emp1);

    }
    @PutMapping
    public Result update(@RequestBody Emp emp){
        empService.update(emp);
        return Result.success();
    }
Service层中的代码:
//TODO 修改员工:先根据id查询到该员工:
    @Override
    public Emp getById(Integer id) {
        Emp emp1=empMapper.getById(id);
        return emp1;
    }
    public void update(Emp emp){
        emp.setUpdateTime(LocalDateTime.now());
        empMapper.update(emp);
    }
Mapper层中的代码:
//TODO 修改员工,先要根据id查询到此员工:
    @Select("select*from emp where id=#{id}")
    Emp getById(Integer id);

    void update(Emp emp);
xml映射文件中的SQL语句:
<update id="update">
        update emp
        <set>
            <if test="username!=null">
                username=#{username},
            </if>
            <if test="password!=null">
                password=#{password},
            </if>
            <if test="name!=null and name!=''">
                name=#{name},
            </if>
            <if test="gender!=null">
            gender=#{gender},
            </if>
            <if test="image!=null and image!=''">
                image=#{image},
            </if>
            <if test="job!=null">
                job=#{job},
            </if>
            <if test="entrydate!=null">
                entrydate=#{entrydate},
            </if>
            <if test="deptId!=null">
                dept_id=#{deptId},
            </if>
            <if test="updateTime!=null">
                update_time=#{updateTime}
            </if>
        where id=#{id}
        </set>
    </update>

以上完成了部门管理以及员工管理操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1442470.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

switch 安装 moonlight 串流

准备工作&#xff1a; 1. 破解的switch 2. 能进行串流&#xff0c;支持moonlight 的电脑&#xff08;nvdia shiled 功能 / sunshine 软件&#xff09; 3. 比较好的网络环境&#xff1a;5Ghz频段wifi的稳定链接 --- 1. 去下载 moonlight 的 nro 包 GitHub - rock88/moonlig…

探索ChatGPT-4:智能会话的未来已来

深入了解ChatGPT-4&#xff1a;前沿AI的强大功能 ChatGPT-4是最先进的语言模型之一&#xff0c;由OpenAI开发&#xff0c;它在自然语言理解和生成方面的能力已经达到了新的高度。如今&#xff0c;ChatGPT-4已经被广泛应用于多个领域&#xff0c;从教育到企业&#xff0c;再到技…

Spring Boot 笔记 003 Bean注册

使用Idea导入第三方jar包这种方法是不对的 使用maven命令导入jar包 官网下载maven Maven – Download Apache Maven 解压缩后在命令行输入命令&#xff0c;注意看输出的结果&#xff0c;安装的是不是你本地的maven仓库 mvn install:install-file -Dfile"D:\common-pojo-2…

CTFSHOW命令执行web入门29-54

description: >- 这里就记录一下ctfshow的刷题记录是web入门的命令执行专题里面的题目,他是有分类,并且覆盖也很广泛,所以就通过刷这个来,不过里面有一些脚本的题目发现我自己根本不会笑死。 如果还不怎么知道写题的话,可以去看我的gitbook,当然csdn我也转载了我自己的…

[SAP ABAP] 创建Package

Package被称作包或开发类&#xff0c;能够存储所有SAP系统开发过程中的相关对象&#xff0c;方便进行管理和查询 我们可以通过Package实现其所包含的对象在不同服务器之间进行批量传输(通过请求号传输) 请求号是文件&#xff0c;用于记录所有对象的创建与修改记录 1.创建Packag…

【Jenkins】Jenkins关闭Jenkins关闭、重启

目录 一、Jenkins关闭、重启 二、Jenkins服务的启动、停止方法。 一、Jenkins关闭、重启 1.关闭Jenkins 只需要在访问jenkins服务器的网址url地址后加上exit&#xff0c;关闭Jenkins服务。 例如&#xff1a;http://localhost:8081/exit 2.重启Jenkies 只有在Jenkins服务启动…

如何在 Mac 上恢复永久删除的文件:有效方法

您是否错误地从 Mac 中删除了某个文件&#xff0c;并且确信它已经永远消失了&#xff1f;好吧&#xff0c;你可能错了。即使您认为已永久删除计算机上的数据&#xff0c;仍有可能将其恢复。 在本文中&#xff0c;您将了解如何在 Mac 上恢复永久删除的文件&#xff0c;并了解增…

天猫数据分析(天猫数据查询工具):2023年滑雪服市场消费现状及趋势(天猫服饰行业分析报告)

随着全民健身的理念逐渐深入人心&#xff0c;滑雪运动产业迎来了前所未有的发展机遇。相关政策的大力支持&#xff0c;冰雪旅游服务设施的日益完善&#xff0c;都为滑雪运动的普及和推广提供了有力保障。 目前&#xff0c;滑雪行业正在蓬勃发展&#xff0c;而在滑雪运动的热潮…

ctfshow-命令执行(web118-web122)

web118 是一个窗口 查看源码 发现是system($code) 命令执行 经过测试禁用了很多东西 很多很多 $IFS可以 思路就是使用系统变量 构造我需要的poc 这些都是系统的环境变量 这是答案${PATH:~A}${PWD:~A}$IFS????.??? 解释一下 PATH变量输出结尾一般都是n 因为网站默认根目…

54.螺旋矩阵(Java)

题目描述&#xff1a; 给你一个 m 行 n 列的矩阵 matrix &#xff0c;请按照 顺时针螺旋顺序 &#xff0c;返回矩阵中的所有元素。 输入&#xff1a; matrix [[1,2,3],[4,5,6],[7,8,9]] 输出&#xff1a; [1,2,3,6,9,8,7,4,5] 代码实现&#xff1a; import java.util.ArrayLi…

Docker overlay2文件busy,容器不能删除问题解决

文章目录 在删除docker容器的时候报错,说设备正忙通过 docker ps -a 查看有两个状态的dead的容器解决方法&#xff1a;1.查看所有挂载的设备2.截取设备的进程id3.清理进程(kill掉即可) 在删除docker容器的时候报错,说设备正忙 Error response from daemon: Driver overlay2 fai…

从一到无穷大 #23 《流计算系统图解》书评

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。 本作品 (李兆龙 博文, 由 李兆龙 创作)&#xff0c;由 李兆龙 确认&#xff0c;转载请注明版权。 文章目录 引言内容总结 引言 春节假期回到家里断然是不会有看纸质书的时间的。造化弄人&#…

python-游戏篇-初级-超级画板

文章目录 开发环境要求运行方法PyCharmVScode 代码main.pytools.py 效果 开发环境要求 本系统的软件开发及运行环境具体如下。 操作系统&#xff1a;Windows 7、Windows 10。Python版本&#xff1a;Python 3.7.1。开发工具&#xff1a;PyCharm 2018。Python内置模块&#xff…

政安晨:示例演绎TensorFlow的官方指南(三){快速使用数据可视化工具TensorBoard}

这篇文章里咱们演绎TensorFLow的数据可视化工具&#xff1a;TensorBoard。 在机器学习中&#xff0c;要改进模型的某些参数&#xff0c;您通常需要对其进行衡量。TensorBoard 是用于提供机器学习工作流期间所需测量和呈现的工具。它使您能够跟踪实验指标&#xff08;例如损失和…

STM32 定时器

目录 TIM 定时器定时中断 定时器外部时钟 PWM驱动LED呼吸灯&#xff08;OC&#xff09; PWM控制舵机 PWMA驱动直流电机 输入捕获模式测频率&#xff08;IC&#xff09; 输入捕获模式测占空比 编码器接口测速(编码器接口) TIM 通用定时器 高级定时器 定时器定时中断 Ti…

材料非线性Matlab有限元编程:初应力法与初应变法

导读:本文主要围绕材料非线性问题的有限元Matlab编程求解进行介绍,重点围绕牛顿-拉普森法(切线刚度法)、初应力法、初应变法等三种非线性迭代方法的算法原理展开讲解,最后利用Matlab对材料非线性问题有限元迭代求解算法进行实现,展示了实现求解的核心代码。这些内容都将收…

Spring基础 - Spring核心之控制反转(IOC)

Spring基础 - Spring核心之控制反转(IOC) 引入 Spring框架管理这些Bean的创建工作&#xff0c;用户管理Bean转变为框架管理Bean&#xff0c;这个称之为控制翻转Spring框架托管创建的Bean放在IOC容器中Spring框架为了更好让用户配置Bean&#xff0c;必然会引入不同方式来配置B…

5G NR 频率计算

5G中引入了频率栅格的概念&#xff0c;也就是小区中心频点和SSB的频域位置不能随意配置&#xff0c;必须满足一定规律&#xff0c;主要目的是为了UE能快速的搜索小区&#xff1b;其中三个最重要的概念是Channel raster 、synchronization raster和pointA。 1、Channel raster …

OpenEuler20.03LTS SP2 上安装 OpenGauss3.0.0 单机部署过程(二)

开始安装 OpenGauss 数据库 3.1.7 安装依赖包 (说明:如果可以联网,可以通过网络 yum 安装所需依赖包,既可以跳过本步骤。如果网络无法连通,请把本文档所在目录下的依赖包上传到服务器上,手工安装后,即无需通过网络进行 Yum 安装了): 上传:libaio-0.3.111-5.oe1.x8…

微信小程序checkbox多选

效果图 <view class"block"><view class"header"><view class"header-left"><text class"pu-title">数据</text><text class"pu-tip">至少选择一个指标</text></view>&l…