zoukankan      html  css  js  c++  java
  • 探讨:通过循环数组或者集合,插入数据库中没有的数据

    【场景】

    要将一组物品 As 放入盒子 Bs 中,如果盒子有该物品,则不把该物品放入盒子。

    即,通过循环数组或者集合,插入数据库中没有的数据。

    【业务分析】

    经常会有初学者进行类似于如下的循环判断

    for(A a : As){
        for(B b : Bs){
            if (B.equals(A)) {
                break;
            } else {
                insert(A)
            }
        }
    }

    这段代码存在如下问题:
    1. 在判断 Bs 中是否有 a 时,会把 Bs 中的所有物品与 a 对比,此时只要 Bs 中有与 a 不相等的物品,就会把 a 插入到数据库。换句话说就是,Bs 中有多个与 a 不相等的物品,那么 a 将被多次插入到数据库中。
    2. 如果 Bs 只有两个物品,那么你将很难从数据库中的数据发现这个问题。

    而正确的逻辑判断应该是如下代码:

    /**
    * 声明一个标志,默认数据时可以插入数据库的
    * 当出现相等的时候,将该标志设置为 false。
    * 当不相等时,不对标志进行处理
    * 循环完成后,再对标志进行判断,
    * true,表示循环中没有相同的物品,可以插入
    * false,表示循环中有相同的物品,不插入
    */
    flag in = true
    for(A a : As){
        for(B b : Bs){
            if (B.equals(A)) {
               in = false;
               break;
            }
        }
        if(in){
            insert(A)
        }
    }
    
    

    如果你有更优化的方案,请在评论区回复。欢迎大家指正。

  • 相关阅读:
    前端把html表格生成为excel表格
    图片预加载
    angular开发中的两大问题
    3d图片点击切换
    图片懒加载
    angular排序
    vue1.0 与 Vue2.0的一些区别 及用法
    图片懒加载
    图片放大镜
    图片小精灵 & 解决同时给一个元素设置背景问题 &jq登录注册切换
  • 原文地址:https://www.cnblogs.com/zhenggc/p/13655507.html
Copyright © 2011-2022 走看看