MongoException:带名称的索引:代码已存在,具有不同的选项

fai*_*izi 9 mongodb mongodb-java spring-data-mongodb mongodb-indexes

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

{
    "_id" : "00002c34-a4ca-42ee-b242-e9bab8e3a01f",
    "terminologyClass" : "USER",
    "code" : "X67",
    "terminology" : "some term related notes",
    "notes" : "some notes"
}
Run Code Online (Sandbox Code Playgroud)

和一个表示术语集合的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
}
Run Code Online (Sandbox Code Playgroud)

term收藏了很多文件.现在我添加了一个新字段Term.javaas

@Indexed
protected String status;
Run Code Online (Sandbox Code Playgroud)

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

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

我使用的是MongoDB版本:2.6.5和spring-data-mongodb版本:1.3.2

Ori*_*Dar 11

您已经在该集合上具有相同名称的索引,但具有不同的定义.我的猜测是你当前的代码索引是非唯一的

尝试: db.Term.getIndexes()

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

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

或者,从@Indexed注释中删除唯一属性(如果除了它之外不是唯一的).