2

所以我的问题是在我的生产数据库中自动创建集合,这些集合旨在包含临时数据(但从逻辑上讲,这些临时文档中的任何一个都不会填充)。为什么会这样,我该如何避免这种行为?

例如更正式的解释,我有两个数据库 - 以及它们包含的集合

productiveDB.coll1
productiveDB.coll2

temporaryDB.col3
temporaryDB.col4

但是当我开始存储数据时,spring会自动创建

productiveDB.coll1
productiveDB.coll2
productiveDB.col3
productiveDB.col4

作为记录:我已经在使用 1.1.1.RELEASE。我创建了一个小测试用例,其中重复了这种行为:两个文档(MyDocOne 和 MyDocTwo)都在自定义字段上包含 @Indexed 注释 - 它们还包含对象类型的字段。因此,当我创建实体myDocOne and myDocTwo- 设置myDocTwo.obj = myDocOne和持久化时 - spring在......中myDocTwo创建了一个集合,这有点令人困惑 - 我希望下面的代码能提供更好的概述。myDocOnetemplate2

public static void main(String[] args ) {
    App app = new App();
    ApplicationContextLoader loader = new ApplicationContextLoader();
    loader.load(app, "applicationContext.xml");

    MongoTemplate template1;
    MongoTemplate template2;

    try {
        template1 = new MongoTemplate(new Mongo("localhost"), "tmp1");
        template1.setApplicationContext(loader.getApplicationContext());
        template2 = new MongoTemplate(new Mongo("localhost"), "tmp2");
        template2.setApplicationContext(loader.getApplicationContext());
        MyDocOne one = new MyDocOne("foo", "bar");
        template1.save(one);            
        MyDocTwo two = new MyDocTwo("foo", "baz");
        two.setAny(one);
        template2.save(two);

    } catch (Exception e) {
            e.printStackTrace();
    }
}

和文件:

@Document
public class MyDocOne {

    @Indexed
    String a;
    String b;

    public MyDocOne(String a, String b) {
        super();
        this.a = a;
        this.b = b;
    }
}

@Document
public class MyDocTwo {
    @Indexed
    String a;
    String b;
    Object any;

    public MyDocOne(String a, String b) {
        super();
        this.a = a;
        this.b = b;
    }

    public void setAny(Object any) {
        this.any = any;
    }
}
4

1 回答 1

2

目前这是不可能的。MongoDB 中的集合在写入时会延迟创建,并且在它们变为空时不会自动删除。有几个开放的 JIRA 问题或与之相关的行为,特别是:

https://jira.mongodb.org/browse/SERVER-610

https://jira.mongodb.org/browse/SERVER-3215

您将不得不手动清理空集合。定期扫描所有数据库以查找空集合并删除它们(可选地,仅当集合名称以特定字符串为前缀时,例如“temp”)将起到作用。

于 2012-12-14T10:02:38.017 回答