Spring Boot案例-员工分页查询

准备工作:

数据库的连接:


#驱动类名称
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#数据库连接的url
spring.datasource.url=jdbc:mysql://localhost:3306/tlias
#连接数据库的用户名
spring.datasource.username=root
#连接数据库的密码
spring.datasource.password=123456#配置mybatis的日志, 指定输出到控制台
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl#开启mybatis的驼峰命名自动映射开关 a_column ------> aCloumn
mybatis.configuration.map-underscore-to-camel-case=true

PageBean: 返回给前端的格式限制

其他的都是那三层架构

Controller: 写的是前端发送过来的请求,然后对相应的请求做出对应的响应

Service: 逻辑的处理

Dao: 把对应的java语句转换为SQL语句,然后对数据库进行操作

Controller(对前端的请求做出响应):

package com.example.tliaswebmanagement.controller;import com.example.tliaswebmanagement.pojo.PageBean;
import com.example.tliaswebmanagement.pojo.Result;
import com.example.tliaswebmanagement.service.EmpService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;@Slf4j
@RestController
public class EmpController {@Autowiredprivate EmpService empService;@GetMapping("/emps")public Result page(@RequestParam(defaultValue = "1") Integer page,@RequestParam(defaultValue = "10") Integer pageSize) {log.info("分页查询,参数: {}, {}", page, pageSize);PageBean pageBean =  empService.page(page, pageSize);return Result.success(pageBean);}
}

代码分析:

@slf4j 就等同于下面这个代码,是日志的记录

private static Logger log = LoggerFactory.getLogger(DeptController.class);

 @RestController 会将方法的返回值返回给前端,返回的形式转换为JSON的形式

@Autowired 是 Spring Framework 提供的一种依赖注入(DI)方式,它可以自动装配一个 Spring 容器中已经注册的 bean 对象到需要使用这些对象的类中。通过 @Autowired 注解,Spring 会自动查找相应类型的 bean,然后将其注入到被注解的字段、方法或构造函数参数中。

@GetMapping(url) 这个注解是写在一个方法的上面的,用于处理 HTTP GET 请求,当浏览器的请求和这个url一样的时候,会执行这个注解下面的方法

@RequestParam 用于将HTTP请求中的参数绑定到方法的参数上。在Java Spring框架中,它可以用于处理HTTP GET请求的查询参数或者POST请求的表单数据, 它里面的 defaultValue属性是指定参数的默认值,当请求中没有该参数时,会使用默认值。

自动创建一个接口的实现类

 @Autowiredprivate EmpService empService;

调用这个对象的相关方法,进行逻辑处理

 Service(逻辑处理):

接口:

package com.example.tliaswebmanagement.service;import com.example.tliaswebmanagement.pojo.PageBean;
import org.apache.ibatis.annotations.Mapper;public interface EmpService {PageBean page(Integer page, Integer pageSize);
}

实现:

package com.example.tliaswebmanagement.service.impl;import com.example.tliaswebmanagement.mapper.EmpMapper;
import com.example.tliaswebmanagement.pojo.Emp;
import com.example.tliaswebmanagement.pojo.PageBean;
import com.example.tliaswebmanagement.service.EmpService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.util.List;@Service
public class EmpServicelmpl implements EmpService {@Autowiredprivate EmpMapper empMapper;@Overridepublic PageBean page(Integer page, Integer pageSize) {//获取总的记录数Long count = empMapper.count();//获取分页查询结果列表List<Emp> list = empMapper.page((page - 1) * pageSize, pageSize);//封装PageBean对象PageBean pageBean = new PageBean(count, list);return  pageBean;}
}

代码分析:

为什么去特意定义一个接口呢?解除耦合,为了后期的维护和管理

@Service 在Spring中,使用@Service注解表示这是一个服务层组件,也就是业务逻辑层的实现类。@Service注解放置在类上,表示这个类是一个Spring的Service,用于标注业务层组件。当我们需要在Controller中调用Service层方法时,可以使用@Autowired注解进行自动注入。

在这里面和dao结合起来,也是为了后期的方便 解除耦合

 @Autowiredprivate EmpMapper empMapper;

Dao(操作数据库):

package com.example.tliaswebmanagement.mapper;import com.example.tliaswebmanagement.pojo.Emp;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;import java.util.List;@Mapper
public interface EmpMapper {@Select("select count(*) from emp")public Long count();@Select("select * from emp limit #{start}, #{pageSize}")public List<Emp> page(Integer start, Integer pageSize);}

@Mapper 在MyBatis框架中,@Mapper注解用于标识一个接口是MyBatis的Mapper接口。这个注解告诉MyBatis根据接口定义创建一个实现类,并将其注册为Mapper。这样你就可以通过该接口调用数据库操作方法

@Select("") 这个写在一个方法的前面,意思就是当你调用这个方法的时候 他会执行的SQL操作

 @Select("select count(*) from emp")public Long count();

运行:

在Postman里面进行访问

运行的结果:

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++初阶——权限与继承

目录 一、C权限方面的问题 1.访问权限 2.继承机制 二、Cconst引用 const引用有以下几个特点 临时对象引用 常量引用成员变量 二、c引用空间相关问题 三.auto 一、C权限方面的问题 【C入门】访问权限管控和继承机制详解_权限继承功能-CSDN博客文章浏览阅读840次。(2)但…

Android 跨进程之间通信(IPC)方式之ContentProvider

Android 跨进程之间通信 Android 跨进程之间通信(IPC)方式之BroadcastReceiverAndroid 跨进程之间通信(IPC)方式之ContentProvider 文章目录 Android 跨进程之间通信前言一、ContentProvider 是什么&#xff1f;二、如何利用ContentProvider跨进程通信1.创建自定义ContentProv…

在宝塔Linux中安装Docker

前言 帮助使用宝塔的用户快速上手docke的安装 &#x1f4da;&#x1f4da; &#x1f3c5;我是默&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; ​​​​ &#x1f31f;在这里&#xff0c;我要推荐给大家我的专栏《Docker》。&#x1f3af;&#x1f3af…

简单Diff算法

简单Diff算法 渲染器的核心 Diff算法 解决的问题 比较新旧虚拟节点的子节点&#xff0c;实现最小化更新。 虚拟节点key属性的作用 就像虚拟节点的“身份证号”&#xff0c;在更新时&#xff0c;渲染器会通过key属性找到可复用的节点&#xff0c;然后尽可能地通过DOM移动操…

软件测试/测试开发丨Linux 数据处理三剑客学习笔记

一、Linux 三剑客之 grep 1、 内容检索 获取行&#xff08;单行&#xff09; grep pattern file获取内容 grep -o pattern file获取上下文 grep -A -B -C pattern file 2、 文件检索 递归搜索 grep pattern -r dir/展示匹配文件名 grep -H 111 /tmp/1只展示匹配文件名 grep …

[情商-3]:理解男女思维方式、心理诉求、情绪诉求的差别

目录 前言&#xff1a; 一、感性思维 VS 理性思维 1.1 感性思维 VS 理性思维 1.2 情绪 VS 事情本身 1.3 情绪感知 VS 逻辑推理 二、情绪的表达 2.1 表达方式 2.2 表达途径 三、不明说的情绪和倾诉诉求&#xff1a;隐藏在情绪表达方式之下的情绪与情绪诉求 3.0 快乐愉…

常见网络设备及功能详解

网络设备 - 交换机 交换机&#xff1a;距离终端用户最近的设备&#xff0c;用于终端用户接入网络、对数据帧进行交换等。 交换机的功能&#xff1a; 终端设备&#xff08;PC、服务器等&#xff09;的网络接入二层交换&#xff08;Layer 2 Switching&#xff09; 网络设备 - …

思维链COT原理探究

要进行因果分析&#xff0c;需要把思维链中的不同元素拆解开来&#xff0c;然后通过控制变量实验&#xff0c;来研究不同元素对COT效果的影响。以下两篇论文的核心差异就在于: COT的变量拆解&#xff0c;以及控制变量的实验方式。 结合两篇论文的实验结论&#xff0c;可能导致…

如何在Linux系统中安装Redis

原本Redis官网提供了Windows和Linux两个版本&#xff0c;但从 2011-12-29 以后不再更新Windows版本&#xff08;https://github.com/dmajkic/redis/downloads&#xff09;&#xff0c;加之企业生产环境通常使用Linux系统&#xff0c;所以这里在Linux系统中演示如何安装Redis。 …

十八、任务通知

1、前言 (1)所谓“任务通知”&#xff0c;可以反过来读"通知任务"。我们使用队列、信号量、事件组等等方法时&#xff0c;并不知道对方是谁。使用任务通知时&#xff0c;可以明确指定&#xff1a;通知哪个任务。 (2)使用队列、信号量、事件组时&#xff0c;我们都需…

Pycharm引用其他文件夹的py

Pycharm引用其他文件夹的py 方式1&#xff1a;包名设置为Sources ROOT 起包名的时候&#xff0c;需要在该文件夹上&#xff1a;右键 --> Mark Directory as --> Sources ROOT 标记目录为源码目录&#xff0c;就可以了。 再引用就可以了 import common from aoeweb impo…

Select工作原理

I/O多路复用是一种并发处理的机制&#xff0c;允许一个进程通过一种机制监视多个描述符&#xff0c;从而在有多个I/O操作需要处理时选择其中之一进行服务。select 函数是一种常见的实现 I/O 多路复用的系统调用&#xff0c;它允许一个进程同时监视多个文件描述符的可读性、可写…