SpringBoot实战第三天

今天主要完成了:

新增棋子分类

棋子分类列表

获取棋子分类详情

更新棋子分类

更新棋子分类和添加棋子分类_分组校验

新增棋子

新增棋子参数校验

棋子分类列表查询(条件分页)

先给出分类实体类

@Data
public class Category {private Integer id;//主键ID@NotEmptyprivate String categoryName;//分类名称(赛季全名)@NotEmptyprivate String categoryAlias;//分类别名(赛季版本号)private Integer createUser;//创建人IDprivate LocalDateTime createTime;//创建时间private LocalDateTime updateTime;//更新时间
}

新增棋子分类

接口文档

 

读接口文档,需求就是一个@Insert,但是发现接口文档没有考虑到可能会有重复分类的创建,我认为重复分类的创建是不合适的,所以我做了一个分类存在检测以防止重复分类的出现

基本属于User新建的小修小改,直接上代码

Controller层

    @PostMappingpublic Result add(@RequestBody @Validated Category category){String init_name = category.getCategoryName();Category incategory = categoryService.getCategoryByNAME(init_name);if (incategory == null){        categoryService.add(category);return Result.success();} else {return Result.error("棋子分类已存在!");}}

写了一个条件判断来防止重复分类的出现,用json里给的分类名查分类是否存在

Service层

    @Overridepublic void add(Category category) {Map<String,Object> map = ThreadLocalUtil.get();Integer id  = (Integer) map.get("id");category.setCreateTime(LocalDateTime.now());category.setUpdateTime(LocalDateTime.now());category.setCreateUser(id);categoryMapper.add(category);}@Overridepublic Category getCategoryByNAME(String init_name) {Category c = categoryMapper.getCategoryByNAME(init_name);return c;}

一个新增一个查询,为了达成给分类写入创建人相关信息,还是老方法,从ThreadLocal里面取

Mapper层

    @Insert("insert into category(category_name,category_alias,create_user,create_time,update_time) " +"values(#{categoryName},#{categoryAlias},#{createUser},#{createTime},#{updateTime}) ")void add(Category category);@Select("Select * from category where category_name = #{init_name}")Category getCategoryByNAME(String init_name);

 搞定

棋子分类列表

接口文档

 可以看到,这次不需要接入任何参数,返回的是一个棋子分类列表,区别不大,开搞!

ps:突然发现接口文档要求的时间格式跟直接捞出来的localdatatime格式不一样,这是个问题

Controller层

    @GetMappingpublic Result<List<Category>> list(){List<Category> categoryList = categoryService.list();return Result.success(categoryList);}

Service层

    @Overridepublic List<Category> list() {Map<String,Object> map = ThreadLocalUtil.get();Integer id  = (Integer) map.get("id");return categoryMapper.list(id);}

老规矩,ThreadLocal拿用户信息 

Mapper层

    @Select("select * from category where create_user = #{id}")List<Category> list(Integer id);

解决给出时间格式需修改问题 

在实体类中用 @JsonFormat接口

    private LocalDateTime createTime;//创建时间@JsonFormat(pattern = TIME_REGEXP)private LocalDateTime updateTime;//更新时间

RT,相应的也更新了我的正则文件

    public static final String TIME_REGEXP = "^yyyy-MM-dd HH:mm:ss";

搞定收工 

 

获取棋子分类详情

接口文档

 

阅读接口文档,通过分类ID获取分类全部信息,再多考虑下非法ID输入就行

Controller层

    @GetMapping("detail")public Result<Category> getDetail(Integer id){Category category = categoryService.getCategoryByID(id);if (category == null){return Result.error("查询分类不存在!");}else {return Result.success(category);}}

做了个简单逻辑判断来确保查询的分类是存在的 

Service层

    @Overridepublic Category getCategoryByID(Integer init_ID) {return categoryMapper.getCategoryByID(init_ID);}

Mapper层

    @Select("Select * from category where id = #{init_ID}")Category getCategoryByID(Integer init_ID);

 顺手修改下新增棋子接口

由于这个按ID查询棋子和新增棋子接口用的按分类名查询实际上效果一样,为了提高代码复用率,把新增棋子接口的查询直接改成按ID查询,如下:

    @PostMappingpublic Result add(@RequestBody @Validated Category category){Integer init_ID = category.getId();Category incategory = categoryService.getCategoryByID(init_ID);if (incategory == null){        categoryService.add(category);return Result.success();} else {return Result.error("棋子分类已存在!");}}

(别忘了删除其他基层的按分类名查询) 

 

 

更新棋子分类

接口文档

 

 读接口文档,注意下参数校验和身份验证就行

先看Controller层

    @PutMappingpublic Result update(@RequestBody @Validated Category incategory){Category category = categoryService.getCategoryByID(incategory.getId());if (category == null){return Result.error("要修改的分类不存在!");}else {Integer userID = category.getCreateUser();Map<String,Object> map = ThreadLocalUtil.get();Integer id_user  = (Integer) map.get("id");if (userID.equals(id_user)){categoryService.update(incategory);return Result.success();}else {return Result.error("您所要更改的分类不属于您!");}}}

先对要更改的分类存不存在进行验证,如果存在在进行身份验证,都验证通过了就可以进行修改操作了

Service层

    @Overridepublic void update(Category category) {category.setUpdateTime(LocalDateTime.now());categoryMapper.update(category);}

Mapper层

    @Update("update category set category_name = #{categoryName} , category_alias = #{categoryAlias} , update_time = #{updateTime} where id = #{id}")void update(Category category);

对了,要在实体类中给id加一个@NotNull注解来验证

    @NotNullprivate Integer id;//主键ID

搞定收工 

 

更新棋子分类和添加棋子分类_分组校验

由于我们在刚刚写修改棋子分类的时候给ID加上了notnull的注解,导致了在每次检验CateGory对象的时候都会检验id是否为null,而我们在写新增分类的时候由于id是会自增的所以我们并没有传入棋子id。这时,刚刚的更改会导致新增分类接口无法正常使用,为了解决这个问题,我们就要用到分组校验

分组校验

把校验项进行归类分组,在完成不同功能的时候,校验指定组中的校验项

步骤

1.定义分组

使用接口来定义分组

例如我们要给category加add和update两个分组,我们就可以在其实体类中定义如下两个分组

    public interface Add{}public interface Update{}
2.定义校验项时指定归属的分组

如下例:

    @NotNull(groups = Update.class)private Integer id;//主键ID@NotEmpty(groups = {Update.class,Add.class})private String categoryName;//分类名称@NotEmpty(groups = {Update.class,Add.class})private String categoryAlias;//分类别名

可以看到,分组可以同时指定多个,用{}来承接 

3.校验时指定要校验的分组
 public Result add(@RequestBody @Validated(Category.Add.class) Category category){public Result update(@RequestBody @Validated(Category.Update.class) Category incategory){
小优化

校验分组存在如下两条规则

1.如果某个校验项没有指定分组,则默认属于Defult分组

2.分组之间可以继承,A extends B,则A中继承B中所有的校验项目

那么我们可以对上例进行如下优化:

我们可以看到add和update的唯一区别就是对于ID非空的检验,所以我们可以让其他所有校验直接进入Defult组,并让我们自定义的两个分组都继承Defult组,add独立的划入对于ID的飞控检查

@Data
public class Category {@NotNull(groups = Update.class)private Integer id;//主键ID@NotEmptyprivate String categoryName;//分类名称@NotEmptyprivate String categoryAlias;//分类别名private Integer createUser;//创建人ID@JsonFormat(pattern = TIME_REGEXP)private LocalDateTime createTime;//创建时间@JsonFormat(pattern = TIME_REGEXP)private LocalDateTime updateTime;//更新时间public interface Add extends Default {}public interface Update extends Default {}

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

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

相关文章

Spring- FactoryBean接口中的getObject()方法

目录 一、Spring框架介绍 二、FactoryBean接口是什么 三、getObject()方法如何使用 一、Spring框架介绍 Spring框架是一个轻量级的、非侵入式的Java企业级应用开发框架&#xff0c;以IoC&#xff08;控制反转&#xff09;和AOP&#xff08;面向切面编程&#xff09;为核心思…

阿里云服务器租用费用_2024年2月最新价格表

2024年2月阿里云服务器租用价格表更新&#xff0c;云服务器ECS经济型e实例2核2G、3M固定带宽99元一年、ECS u1实例2核4G、5M固定带宽、80G ESSD Entry盘优惠价格199元一年&#xff0c;轻量应用服务器2核2G3M带宽轻量服务器一年61元、2核4G4M带宽轻量服务器一年165元12个月、2核…

百面嵌入式专栏(技能篇)嵌入式技能树详解

沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇我们将介绍嵌入式重点知识。 一、C语言 C语言这一块的高频考点有预处理、关键字、数据类型、指针与内存管理。 预处理有文件包含、宏定义、条件编译,其中最重要的是宏定义,通常考核宏定义的语法、宏替换与函数的区…

Redis核心技术与实战【学习笔记】 - 24.Redis 数据分片方案选择:Codis 和 Redis Cluster

简述 Redis 的切片集群使用多个实例保存数据&#xff0c;能很好的应对大数据量的场景。在《4.Redis 切片集群》中&#xff0c;介绍了 Redis 官方提供的切片集群方法 Redis Cluster。本章&#xff0c;再来学习下&#xff0c;在 Redis Cluster 方案正式发布前&#xff0c;业界广…

算法练习-四数之和(思路+流程图+代码)

难度参考 难度&#xff1a;中等 分类&#xff1a;数组 难度与分类由我所参与的培训课程提供&#xff0c;但需要注意的是&#xff0c;难度与分类仅供参考。且所在课程未提供测试平台&#xff0c;故实现代码主要为自行测试的那种&#xff0c;以下内容均为个人笔记&#xff0c;旨在…

推动海外云手机发展的几个因素

随着科技的不断发展&#xff0c;海外云手机作为一种新兴技术&#xff0c;在未来呈现出令人瞩目的发展趋势。本文将在用户需求、技术创新和全球市场前景等方面&#xff0c;探讨海外云手机在未来的发展。 1. 用户需求的引领&#xff1a; 随着人们对移动性和便捷性的需求不断增长&…

【FPGA】快速学习路径

FPGA学习教程、功利式学习路径、以找工作为目的&#xff0c;早日入门FPGA_哔哩哔哩_bilibili

统计数字出现次数的数位动态规划解法-数位统计DP

在处理数字问题时,我们经常遇到需要统计一定范围内各个数字出现次数的情况。这类问题虽然看起来简单,但当数字范围较大时,直接遍历统计的方法就变得不再高效。本文将介绍一种利用数位动态规划(DP)的方法来解决这一问题,具体来说,是统计两个整数a和b之间(包含a和b)所有…

2024/2/5总结

微信小程序 监听对象中所有属性的变化 如果某个对象中需要被监听的属性太多&#xff0c;为了方便&#xff0c;可以使用 通配符 ** 来监听 对象中所有属性的变化 什么是纯数字字段 概念&#xff1a;纯数字字段指的是那些不用于界面渲染的 data 字段。 好处&#xff1a;提升界面…

AI专题:海外科技巨头指引,AI主线逻辑依旧坚挺

今天分享的是AI 系列深度研究报告&#xff1a;《AI专题&#xff1a;海外科技巨头指引&#xff0c;AI主线逻辑依旧坚挺》。 &#xff08;报告出品方&#xff1a;华西证券&#xff09; 报告共计&#xff1a;54页 本周热点:海外科技巨头指引&#xff0c;AI主线逻辑依旧坚挺 硬件…

为什么(如何)从 Java 8/11 迁移到 Java 21,从 Spring Boot 2 迁移到最新的 Spring Boot 3.2 ?

介绍 如果您的工作配置与 Java 有一定的关系&#xff0c;您一定已经注意到 了Java 最新稳定版本 Java 21 引起了很多关注。 这个新版本引入了一些未来的功能&#xff0c;改进了之前引入/孵化的一些突破性功能&#xff0c;弃用了多余的功能&#xff0c;并删除了一些错误。它使…

【JavaEE Spring 项目】博客系统

博客系统 前⾔项⽬介绍1. 准备⼯作1.1 数据准备1.2 创建项⽬1.3 准备前端⻚⾯1.4 配置配置⽂件1.5 测试 2. 项⽬公共模块2.1 实体类的编写2.2 公共层 3. 业务代码3.1 持久层3.2 实现博客列表3.3 实现博客详情3.4 实现登陆令牌技术JWT令牌介绍JWT令牌⽣成和校验 3.5 实现强制要求…