Java后端开发中使用二分查找的小案例

前言

在传统的Java后端开发过程中,书写最多的代码便是crud。什么是crud呢?简单来说就是,对数据进行增删改查,然后将结果返回给用户。在我们开发过程中使用的数据类型往往是结构化数据,例如MySql当中我们所建立的各种表以及表中的数据。

一个看似不是很合理的需求

  • 更新商品的信息(包括id

乍一看好像也没什么问题,sql语句也好写(mybatis),不就是

bash 复制代码
update table set  id = newId , name = xxx.name where id = xxx.id

实现过程

1、实体类

arduino 复制代码
​
@Data
public class Commodity implements Serializable {
​
    /**
     * 商品ID
     */
    private Integer id;
​
    /**
     * 商品名称
     */
    private String name;
​
    /**
     * 卖家
     */
    private String seller;
​
    /**
     * 库存
     */
    private Integer inventory;
​
    /**
     * 价格
     */
    private Float price;
​
    private static final long serialVersionUID = 797972520302738355L;
​
}

2、mybatis

接口方法 xml文件

3、service层(此处省略)

懂得都懂,我这里也没有进行多余的操作,基本就是复制粘贴,对象注入去实现。

4、controller层

此处就会有问题

如果newId和数据库原来数据发生重复 就会出错,所以我们需要进行校验。 其实就是检验newId是否在数据库已经有的id列表当中。

实现思路

  1. 获取所有商品的id信息存放在idList中 select id from commodity
  2. 使用二分法判断idList是否包含newId
  3. 执行更新操作
此外我就展示controller的代码,因为其他代码的难度不大

思考

  1. id 为主键 ,为什么要修改id呢?所以我才会说这是一个不是很合理的需求
  2. 使用mybatisplus当中的QueryWrapper封装的方法也是可以实现的。
  3. 数据量非常大的情况下,使用二分法去进行查找,效率如何呢?
相关推荐
i***13244 分钟前
SpringCloud实战十三:Gateway之 Spring Cloud Gateway 动态路由
java·spring cloud·gateway
计算机徐师兄6 分钟前
Java基于微信小程序的食堂线上预约点餐系统【附源码、文档说明】
java·微信小程序·食堂线上预约点餐系统小程序·食堂线上预约点餐微信小程序·java食堂线上预约点餐小程序·食堂线上预约点餐小程序·食堂线上预约点餐系统微信小程序
无心水1 小时前
【分布式利器:腾讯TSF】10、TSF故障排查与架构评审实战:Java架构师从救火到防火的生产哲学
java·人工智能·分布式·架构·限流·分布式利器·腾讯tsf
一 乐8 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
Boilermaker19928 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维8 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
alonewolf_999 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子9 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
码事漫谈9 小时前
Protocol Buffers 编码原理深度解析
后端
sheji34169 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java