gpt4 book ai didi

spring - Mongodb upsert 抛出 DuplicateKeyException

转载 作者:行者123 更新时间:2023-12-02 01:39:56 65 4
gpt4 key购买 nike

当我尝试使用方法 [1] 更新插入(增量或插入)文档时,我确实会不时收到此错误 [2]。

[1]

public NGram save(final NGram ngram) {
Criteria cr = where("_id").is(ngram.getNgram())
.and("f3c").is(ngram.getF3c())
.and("tokCount").is(ngram.getTokCount())
.and("first").is(ngram.getFirst())
;
if( ngram.getTokCount() > 1 ) {
cr.and("second").is(ngram.getSecond());
}
if( ngram.getTokCount() > 2 ) {
cr.and("third").is(ngram.getThird());
}
final Query qry = new Query( cr );
final Update updt = new Update().inc("count", ngram.getCount());
template.upsert(qry, updt, NGram.class);
return ngram;
}

[2]

Caused by: org.springframework.dao.DuplicateKeyException: E11000 duplicate key error index: sytrue.ngram.$_id_  dup key: { : "page two" }; nested exception is com.mongodb.MongoException$DuplicateKey: E11000 duplicate key error index: sytrue.ngram.$_id_  dup key: { : "page two" }
at org.springframework.data.mongodb.core.MongoExceptionTranslator.translateExceptionIfPossible(MongoExceptionTranslator.java:52)
at org.springframework.data.mongodb.core.MongoTemplate.potentiallyConvertRuntimeException(MongoTemplate.java:1665)
at org.springframework.data.mongodb.core.MongoTemplate.execute(MongoTemplate.java:390)
at org.springframework.data.mongodb.core.MongoTemplate.doUpdate(MongoTemplate.java:920)
at org.springframework.data.mongodb.core.MongoTemplate.upsert(MongoTemplate.java:894)
at com.sytrue.ngram.repo.impl.NGramRepositoryImpl.save(NGramRepositoryImpl.java:43)
at sun.reflect.GeneratedMethodAccessor41.invoke(Unknown Source)

Upsert 永远不应该向我返回此异常。我说得对吗?

最佳答案

我只是猜测可能存在以下问题:

您正在根据许多条件进行查找操作。这意味着如果由于参数(在标准中)不匹配而失败,那么它将尝试插入文档。

因此,很可能您正在尝试使用相同的 _id 更新同一文档,但其他一些条件不匹配,导致它再次插入,这将导致重复键异常。考虑下面的例子

test:Mongo > db.example.update({ _id : 1, a : 1, b : 1},{ $set : {d : 1}}, true, false)
test:Mongo > db.example.find()
{ "_id" : 1, "a" : 1, "b" : 1, "d" : 1 }
test:Mongo > db.example.update({ _id : 1, a : 1, b : 2},{ $set : {d : 1}}, true, false)
E11000 duplicate key error index: test.example.$_id_ dup key: { : 1.0 }

关于spring - Mongodb upsert 抛出 DuplicateKeyException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16465416/

65 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com