20

我有一个具有以下结构的mongodb集合term

{
    "_id" : "00002c34-a4ca-42ee-b242-e9bab8e3a01f",
    "terminologyClass" : "USER",
    "code" : "X67",
    "terminology" : "some term related notes",
    "notes" : "some notes"
}

和一个将术语集合表示为的 java 类Term.java

@Document
public class Term{  

    @Id
    protected String termId;

    @Indexed
    protected String terminologyClass;

    @Indexed(unique=true)
    protected String code;

    @Indexed
    protected String terminology;

    protected String notes;

    //getters & setters
}

term收集了很多文件。现在我添加了一个新字段Term.java作为

@Indexed
protected String status;

在向集合添加字段statusTerm.java,在向集合中插入一个新术语时,term我得到了一个异常:

com.mongodb.MongoException:索引名称:代码已经存在不同的选项

我正在使用 MongoDB 版本:2.6.5 和 spring-data-mongodb 版本:1.3.2

4

3 回答 3

19

您已经在该集合上有一个同名但定义不同的索引。我的猜测是您当前的代码索引是非唯一的

尝试: db.Term.getIndexes()

如果确实是这种情况(您在代码字段上有一个非唯一索引),请发出:( db.Term.dropIndex("code_1") 替换为代码字段索引名称)。

下次启动应用程序时,它应该可以正常工作。

或者,从@Indexed注释中删除唯一属性(如果您不认为它是唯一的)。

于 2015-05-14T08:10:42.287 回答
4

您是否尝试过放弃收藏并重试?通常在将新的 java 映射应用到现有的 mongodb 集合时会有很多冲突

于 2015-05-14T08:01:48.277 回答
1

尝试创建多个复合文本索引也可能导致此错误。

每个文档的每个集合只允许一个用于文本搜索的文本索引。

在多租户数据库中,我们希望通过使用复合索引来强制每个客户数据的唯一性。

db.users.createIndex( { customer: "text", email: "text"}, { unique: true } );
db.users.createIndex( { customer: "text", cell: "text"}, { unique: true } );

这样做会导致操作错误。

但是,将它们更改为常规索引解决了该问题。

db.users.createIndex( { customer: 1, email: 1}, { unique: true } );
db.users.createIndex( { customer: 1, cell: 1}, { unique: true } );
于 2021-07-05T17:00:45.110 回答