1

我现有的@CompoundIndex 定义如下:

@CompoundIndex(name = "idx_test_search", unique = true,
        def = "{type: 1, origin: 1, date: 1}")

现在我需要更改它以添加另一个字段,例如:

@CompoundIndex(name = "idx_test_search", unique = true,
        def = "{type: 1, origin: 1, date: 1, travelers: 1}")

我希望它会像在应用程序启动时创建一样自动应用,但在 MongoDb 中它仍然是旧的。我可以用新名称创建一个不同的索引,但是我需要删除这个索引。我可以这样做@ChangeSet吗?有任何想法吗?

4

1 回答 1

2

我用 mongoTemplate 和@Changeset 做到了这一点:

@ChangeLog(order = "0.0.1")
public class MongoChangelogVersion_0_0_1 {

    @ChangeSet(order = "0001", id = "testSearchIndex", author = "djordje.ivanovic@****.com")
    public void dropIndex(MongoTemplate mongoTemplate) throws IOException {
        List<IndexInfo> indexes =  mongoTemplate.indexOps(TestSearch.class).getIndexInfo();
        for(IndexInfo indexInfo: indexes){
            if(indexInfo.getName().equals("idx_test_search")){
                mongoTemplate.indexOps(TestSearch.class).dropIndex("idx_test_search");
                break;
            }
        }
    }
}

mongoTemplate.indexOps(TestSearch.class)正在返回相关表的所有索引列表(在我的情况下为 TestSearch),因此在检查索引是否存在后,我们将删除它。

于 2019-08-09T10:20:29.817 回答