public List<GoodsSku> compareList(List<GoodsSku> list1, List<GoodsSku> list2) { // 将list1和list2的skuAttribute字段的值分割、排序后存入set中 Set<String> set1 = new HashSet<>(); Set<String> set2 = new HashSet<>(); list1.forEach(item -> set1.add(Arrays.stream(item.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")))); list2.forEach(item -> set2.add(Arrays.stream(item.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")))); // 遍历list2,如果list1中不包含当前元素,则说明该skuAttribute字段的值为新增,将其插入到数据库中 for (GoodsSku sku : list2) { String sortedSku = Arrays.stream(sku.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")); if (!set1.contains(sortedSku)) { sku.insert(); } } // 遍历list1,如果list2中不包含当前元素,则说明该skuAttribute字段的值需要删除,将其从数据库中删除 for (GoodsSku sku : list1) { String sortedSku = Arrays.stream(sku.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")); if (!set2.contains(sortedSku)) { sku.deleteById(); } } return list1; }
时间: 2024-04-26 13:23:33 浏览: 56
这段代码是用来比较两个商品SKU列表的,它会比较每个SKU的skuAttribute字段的值,将其分割并排序后存储到两个Set中。然后,它会遍历第二个SKU列表,如果第一个SKU列表中不包含当前元素,则说明该SKU的skuAttribute字段的值为新增,它会将其插入到数据库中。接着,它会遍历第一个SKU列表,如果第二个SKU列表中不包含当前元素,则说明该SKU的skuAttribute字段的值需要删除,它会将其从数据库中删除。最后,该方法会返回第一个SKU列表。
相关问题
public Map<String, List<GoodsSku>> compareList(List<GoodsSku> list1, List<GoodsSku> list2) { Map<String, List<GoodsSku>> map = new HashMap<String, List<GoodsSku>>(); List<GoodsSku> duplicateList = new ArrayList<>(); // 重复的skuAttribute字段的值 List<GoodsSku> uniqueList = new ArrayList<>(); // 不重复的skuAttribute字段的值 // 将list1和list2的skuAttribute字段的值分割、排序后存入set中 Set<String> set1 = new HashSet<>(); Set<String> set2 = new HashSet<>(); list1.forEach(item -> set1.add(Arrays.stream(item.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")))); list2.forEach(item -> set2.add(Arrays.stream(item.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")))); // 遍历list1,如果list2中包含当前元素,则说明该skuAttribute字段的值重复,将其加入结果集中;否则加入uniqueList中 for (GoodsSku sku : list1) { String sortedSku = Arrays.stream(sku.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")); if (set2.contains(sortedSku)) { duplicateList.add(sku); } else { uniqueList.add(sku); } } map.put("duplicateList", duplicateList); map.put("uniqueList", uniqueList); return map; }是什么意思
这段代码的作用是比较两个 `GoodsSku` 对象列表 `list1` 和 `list2` 中的 `skuAttribute` 字段的值,将比较结果保存到一个 `Map` 中并返回。
具体实现逻辑如下:
1. 创建一个 `Map` 对象 `map` 用于保存比较结果,其中包含两个键值对:`"duplicateList"` 和 `"uniqueList"`。`"duplicateList"` 对应的值是一个 `List`,表示重复的 `skuAttribute` 字段的值所对应的 `GoodsSku` 对象列表;`"uniqueList"` 对应的值也是一个 `List`,表示不重复的 `skuAttribute` 字段的值所对应的 `GoodsSku` 对象列表。
2. 创建两个 `Set` 对象 `set1` 和 `set2`,分别用于存储 `list1` 和 `list2` 中的 `skuAttribute` 字段的值按 ":" 分割后排序后的结果,以去重。
3. 分别遍历 `list1` 和 `list2`,将每个 `GoodsSku` 对象的 `skuAttribute` 字段的值按 ":" 分割后排序后的结果存入 `set1` 和 `set2` 中。
4. 遍历 `list1` 中的每个 `GoodsSku` 对象,将其 `skuAttribute` 字段的值按 ":" 分割后排序后的结果与 `set2` 进行比较,如果存在相同的值,则将该 `GoodsSku` 对象加入到 `duplicateList` 中,否则加入到 `uniqueList` 中。
5. 将 `duplicateList` 和 `uniqueList` 分别作为值,放入 `map` 中对应的键值对中。
6. 返回 `map` 对象。
综上所述,该方法的作用是比较两个 `GoodsSku` 对象列表中的 `skuAttribute` 字段的值,将结果分类保存到 `Map` 对象中,并返回该对象。
/** * sku信息修改 * * @param list1 已录入库的sku信息 * @param list2 新组合的sku信息 * @return */ public List<GoodsSku> compareList(List<GoodsSku> list1, List<GoodsSku> list2) { Map<String, List<GoodsSku>> map = new HashMap<String, List<GoodsSku>>(); List<GoodsSku> duplicateList = new ArrayList<>(); // 重复的skuAttribute字段的值 List<GoodsSku> uniqueList = new ArrayList<>(); // 不重复的skuAttribute字段的值 // 将list1和list2的skuAttribute字段的值分割、排序后存入set中 Set<String> set1 = new HashSet<>(); Set<String> set2 = new HashSet<>(); list1.forEach(item -> set1.add(Arrays.stream(item.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")))); list2.forEach(item -> set2.add(Arrays.stream(item.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")))); // 遍历list1,如果list2中包含当前元素,则说明该skuAttribute字段的值重复,将其加入结果集中;否则加入uniqueList中 for (GoodsSku sku : list1) { String sortedSku = Arrays.stream(sku.getSkuAttribute().split(":")).sorted().collect(Collectors.joining(":")); if (set2.contains(sortedSku)) { duplicateList.add(sku); } else { uniqueList.add(sku); } } for (GoodsSku sku : uniqueList) {//将不同的sku信息写入库 if (null == sku.getId()) { sku.insert(); } else { sku.deleteById(); } } map.put("duplicateList", duplicateList); map.put("uniqueList", uniqueList); return list1; }
这是一个Java方法,用于比较两个List<GoodsSku>对象,找出其中重复和不重复的skuAttribute值,并将不重复的sku信息写入数据库中。该方法接收两个List<GoodsSku>类型的参数list1和list2,分别表示已录入库的sku信息和新组合的sku信息。比较过程中,首先将每个sku的skuAttribute字段的值分割、排序后存入set中,以便后续比较。然后遍历list1,如果list2中包含当前元素,则说明该skuAttribute字段的值重复,将其加入结果集中;否则加入uniqueList中。最后将uniqueList中的sku信息写入数据库。该方法返回值为List<GoodsSku>类型的list1,表示已录入库的sku信息。
阅读全文
相关推荐














