java8 对象转map时重复key Duplicate key 该如何解决?

当使用Java8的Lambda表达式将集合对象的属性转化为Map时,如果出现DuplicateKey异常,可以通过使用`Collectors.toMap`的另一个重载方法来解决。该方法接受一个合并函数作为参数,可以设置为覆盖前一个值或者合并值。例如,可以选择用后面的值覆盖前面的值,或者将两个值拼接。此外,还可以将重复的key映射到一个列表中,将所有值都保存下来。
摘要由CSDN通过智能技术生成

我们在利用java8  Lambda 表达式将集合中对象的属性转成Map时就会出现 Duplicate key  xxxx , 说白了也就是key 重复了!案例如下:

@Data
@NoArgsConstructor
@AllArgsConstructor
class Person{
    private String className;
    private String studentName;
}
public class DuplicateKey {
    public static void main(String[] args) {
        List<Person> list = new ArrayList<>();
        list.add(new Person("一班", "小明"));
        list.add(new Person("二班", "小芳"));
        list.add(new Person("一班", "小华"));

        Map<String, String> map = list.stream().collect(Collectors.toMap(Person::getClassName, Person::getStudentName));
        System.out.println(map);
    }
}

  此时就会出现Duplicate key  xxxx 这个问题,那怎么解决呢?其实很简单,有三种方法     

  • 我们需要使用toMap的另外一个重载的方法!

        Collectors.toMap(keyMapper, valueMapper, mergeFunction)

        作用:重复时采用后面的value 覆盖前面的value

Map<String, String> map = list.stream().collect(Collectors.toMap(Person::getClassName, Person::getStudentName,(key1,key2)->key1));
  • 重复时将之前的value 和现在的value拼接或相加起来;        
Map<String, String> map = list.stream().collect(Collectors.toMap(Person::getClassName, Person::getStudentName,(key1,key2)->key1+", "+key2));
  • 将重复key的数据变成一个集合!
Map<String, List<String>> map = list.stream().
        collect(Collectors.toMap(Person::getClassName, s -> {
            List<String> studentNameList = new ArrayList<>();
            studentNameList.add(s.getStudentName());
            return studentNameList;
        }, (List<String> value1, List<String> value2) -> {
            value1.addAll(value2);
            return value1;
        }));
System.out.println(map);
Java 的 MyBatis 中,`ON DUPLICATE KEY UPDATE` 是一种在数据库插入操作中处理重复键冲突的机制。它通常用于 MySQL 数据库中的插入语句。 当你想要向数据库表中插入一行数据,但是该行数据的主键或唯一索引与已存在的数据冲突,`ON DUPLICATE KEY UPDATE` 语句提供了一种解决方案。它允许你在冲突发生执行更新操作,而不是简单地抛出错误。 在 MyBatis 的 XML 映射文件中,你可以使用 `ON DUPLICATE KEY UPDATE` 语句来处理重复键冲突。以下是一个示例代码: ```xml <!-- your-mapper.xml --> <insert id="insertOrUpdate" parameterType="YourObject"> INSERT INTO your_table (column1, column2, ...) VALUES (#{property1}, #{property2}, ...) ON DUPLICATE KEY UPDATE column1 = #{property1}, column2 = #{property2}, ... </insert> ``` 在上述代码中,`INSERT INTO` 子句用于插入数据,`VALUES` 子句用于指定要插入的值。接下来的 `ON DUPLICATE KEY UPDATE` 子句用于指定在出现重复键冲突执行的更新操作。你可以通过列名和属性名的对应关系来更新相应的列。 需要注意的是,`ON DUPLICATE KEY UPDATE` 仅适用于具有唯一索引或主键约束的列。如果在插入没有重复键冲突,将会执行插入操作;如果有冲突,将会执行更新操作。 此外,`ON DUPLICATE KEY UPDATE` 语句在不同的数据库中可能有所不同,具体的语法和支持程度可能会有差异。请根据你所使用的数据库类型和版本进行相应的调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值