java8 对象转 Map 时 key Duplicate key

报错信息:

Duplicate key SpotDiffBudgetDTO

java.lang.IllegalStateException: Duplicate key...

问题代码:

Map<String, SpotDiffBudgetDTO> spotMap = list.stream().collect(Collectors
    .toMap(SpotDiffBudgetDTO::getSpotId, 
    spotDiffBudgetDTO -> spotDiffBudgetDTO));

原因解析:

生成Map的key时重复,导致错误,key冲突(因为Map的key必须保持唯一性!)

解决方案:

转换时使用另外一种写法,当遇到key冲突时选取第一个获第二个做key

代码:

case1:
Map<String, SpotDiffBudgetDTO> spotMap = list.stream().collect(Collectors
    .toMap(SpotDiffBudgetDTO::getSpotId,
        item->item,
        (k1,k2) ->k1));

case2:
Map<String, SpotDiffBudgetDTO> spotMap = list.stream().collect(Collectors
    .toMap(SpotDiffBudgetDTO::getSpotId,
        spotDiffBudgetDTO -> spotDiffBudgetDTO,
        (getSpotId,spotDiffBudgetDTO) ->getSpotId));

源码:

 public static <T, K, U>
    Collector<T, ?, Map<K,U>> toMap(Function<? super T, ? extends K> keyMapper,
                                    Function<? super T, ? extends U> valueMapper) {
        return toMap(keyMapper, valueMapper, throwingMerger(), HashMap::new);
    }

    public static <T, K, U>
    Collector<T, ?, Map<K,U>> toMap(Function<? super T, ? extends K> keyMapper,
                                    Function<? super T, ? extends U> valueMapper,
                                    BinaryOperator<U> mergeFunction) {
        return toMap(keyMapper, valueMapper, mergeFunction, HashMap::new);
    }

参考:https://blog.csdn.net/TP89757/article/details/108447594

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
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
发出的红包

打赏作者

Adam`南帝·梁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值