【无标题】

Day17

Tlias智能学习系统

员工管理:

条件分页查询:

三层架构中,每一层的职责如下:

1.Controller:接收参数(分页、条件);调用service,进行分页查询,获取PageResult;响应结果。

具体实现:

java 复制代码
/**
     * 分页查询
     */
    @GetMapping
    public Result page (@RequestParam(defaultValue = "1") Integer page,
                        @RequestParam(defaultValue = "10") Integer pageSize,
                        String name, Integer gender,
                        @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate begin,
                        @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate end){
        log.info("分页查询:{},{},{},{},{},{}",page,pageSize,name,gender,begin,end);
        PageResult<Emp> pageResult = empService.page(page,pageSize,name,gender,begin,end);
        return Result.success(pageResult);
    }

2.Service:使用PageHelper完成分页条件查询;封装PageResult对象,返回。

具体实现:(基本不动)

java 复制代码
public PageResult<Emp> page(Integer page, Integer pageSize, String name, Integer gender, LocalDate begin,LocalDate end) {
        //1.设置分页参数(PageHelper)
        PageHelper.startPage(page,pageSize);
​
        //2.执行查询
        List<Emp> empList = empMapper.list(name,gender,begin,end);
​
        //3.解析查询结果,并封装
        Page<Emp> p = (Page<Emp>) empList;
        return new PageResult<Emp>(p.getTotal(),p.getResult());
​
    }

3.Mapper:SQL:

sql 复制代码
select e.*,d.name deptName from emp e left join dept d on e.dept_id = d.id
                           where e.name like '%阮%' and e.gender = 1 and e.entry_date between '2010-0101' and '2020-01-01'
                           order by e.update_time desc;

具体实现:

java 复制代码
@Mapper
public interface EmpMapper {
 public List<Emp> list(String name, Integer gender, LocalDate begin, LocalDate end);
}

由于查询语句复杂所以用配置文件:

XML 复制代码
<!--定义Mapper映射文件的约束和基本结构-->
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.itheima.mapper.EmpMapper">
    <select id="list" resultType="com.itheima.pojo.Emp">
        select e.*, d.name deptName from emp as e left join dept as d on e.dept_id = d.id
        where e.name like concat('%',#{name},'%')
          and e.gender = #{gender}
          and e.entry_date between #{begin} and #{end}
        order by e.update_time desc
    </select>
</mapper>

请求参数接收优化方案:

如果controller方法的参数较多,且未来可能继续增加,这会使得方法签名变得复杂难以维护,此时可以考虑将多个请求参数封装为一个对象。

java 复制代码
package com.itheima.pojo;
​
import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;
​
import java.time.LocalDate;
@Data
public class EmpQueryParam {
    private Integer page = 1;//页码
    private Integer pageSize = 10;//每页展示记录数
    private String name;//姓名
    private Integer gender;//性别
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    private LocalDate begin;//入职时间-开始
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    private LocalDate end;//入职时间-结束
}

动态SQL:

随着用户的输入或外部条件的变化而变化的SQL语句,我们成为动态SQL。

<if>:判断条件是否成立,如果条件为true,则拼接SQL。

<where>:根据查询条件,来生成where关键字,并会自动去除条件前面多余的and或or。

XML 复制代码
<!--定义Mapper映射文件的约束和基本结构-->
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.itheima.mapper.EmpMapper">
    <select id="list" resultType="com.itheima.pojo.Emp">
        select e.*, d.name deptName from emp as e left join dept as d on e.dept_id = d.id
        where
            <if test="name!=null and name!=''">
            e.name like concat('%',#{name},'%')
          </if>
            <if test="gender!=null">
          and e.gender = #{gender}
          </if>
            <if test="begin!=null and end!=null">
          and e.entry_date between #{begin} and #{end}
            </if>
        order by e.update_time desc
    </select>
</mapper>
相关推荐
道1993几秒前
50 台小型无人车与50套穿戴终端 5 公里范围内通信组网方案深度研究
java·后端·struts
迎風吹頭髮6 分钟前
UNIX下C语言编程与实践35-UNIX 守护进程编写:后台执行、脱离终端、清除掩码与信号处理
java·c语言·unix
光军oi22 分钟前
全栈开发杂谈————JAVA微服务全套技术栈详解
java·开发语言·微服务
帮帮志23 分钟前
目录【系列文章目录】-(关于帮帮志,关于作者)
java·开发语言·python·链表·交互
聪明的笨猪猪23 分钟前
Java Spring “MVC ”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
Boop_wu2 小时前
[数据结构] Map和Set
java·数据结构·算法
一勺菠萝丶2 小时前
Mac 上用 Homebrew 安装 JDK 8(适配 zsh 终端)完整教程
java·python·macos
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 办公自动化管理系统为例,包含答辩的问题和答案
java·eclipse
李宥小哥6 小时前
C#基础11-常用类
android·java·c#
小许学java7 小时前
数据结构-ArrayList与顺序表
java·数据结构·顺序表·arraylist·线性表