我有一个mongodb
集合term
,其结构如下
{
"_id" : "00002c34-a4ca-42ee-b242-e9bab8e3a01f",
"terminologyClass" : "USER",
"code" : "X67",
"terminology" : "some term related notes",
"notes" : "some notes"
}
和表示术语集合为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;
将字段status
添加到Term.java
后,在向term
集合中添加新字词时,我得到的是例外情况:
com.mongodb.MongoException:带名称的索引:代码已存在 不同的选择
我使用的是MongoDB版本:2.6.5和spring-data-mongodb版本:1.3.2
答案 0 :(得分:9)
您已经在该集合上使用相同名称的索引,但定义不同。我的猜测是你当前的代码索引是非唯一的
尝试:
db.Term.getIndexes()
如果确实如此(您在代码字段上有一个非唯一索引),请发出:
db.Term.dropIndex("code_1")
(替换为代码字段索引名称)。
下次启动应用程序时,它应该可以正常工作。
或者,从@Indexed
注释中删除唯一属性(如果您不这样做,除非它是唯一的)。
答案 1 :(得分:1)
你试过放弃你的收藏并再试一次吗?通常在将新的java映射应用于现有的mongodb集合时存在许多冲突
答案 2 :(得分:1)
尝试创建多个复合text 索引也会导致此错误。
每个集合 per the docs 只允许一个用于文本搜索的 text 索引。
在多租户数据库中,我们希望通过使用复合索引来确保每个客户数据的唯一性。
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 } );