Java对List<>根据字段进行分组,并将数据存入到数据库中
时间: 2023-06-02 17:07:01 浏览: 96
好的,这个问题可以回答。您可以使用Java Stream API的groupingBy方法对List进行分组,然后使用JDBC将数据存入数据库中。具体实现方法可能因为你使用的数据库和表结构不同而有所不同,需要使用相应的语法和实现方式。
相关问题
/** * 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信息。
mybatis将数组存入到数据库中
在 MyBatis 中,可以使用 XML 或注解方式编写 SQL 语句,实现将数组存入到数据库中。以下是使用 XML 方式的示例:
1. 在 Mapper.xml 文件中编写 SQL 语句:
```xml
<insert id="insertArray" parameterType="java.util.List">
INSERT INTO table_name (column_name) VALUES
<foreach collection="list" item="item" separator=",">
(#{item})
</foreach>
</insert>
```
2. 在 Java 代码中调用 Mapper 方法:
```java
List<Integer> array = new ArrayList<>();
array.add(1);
array.add(2);
array.add(3);
mapper.insertArray(array);
```
这样就可以将数组存入到数据库中了。需要注意的是,这里使用了 MyBatis 的 foreach 标签,可以遍历 List 中的每个元素,并将其插入到数据库中。同时,需要确保数据库表的字段类型与 List 中元素类型一致,否则会抛出类型转换异常。
阅读全文