1

在项目中,我们需要根据日期每天更改集合名称后缀。

所以一日收藏被命名为:

samples_22032019

第二天就是

samples_23032019

因此,我每天都需要更改后缀并重新编译 spring-boot 应用程序。有什么办法可以改变它,以便可以根据当前日期动态计算集合/表?对 MongoRepository 有什么建议吗?

4

2 回答 2

1

考虑到以下是你的豆子。您可以使用带有 Spring 表达式语言的 @Document 注释在运行时解析后缀。如下图所示,

@Document(collection = "samples_#{T(com.yourpackage.Utility).getDateSuffix()}")
public class Samples {
   private String id;
   private String name;
}

现在在一个实用方法中拥有您的日期更改功能,spring 可以在运行时解决该方法。SpEL 在这种情况下很方便。

package com.yourpackage;

public class Utility {
  public static final String getDateSuffix() {
     //Add your real logic here, below is for representational purpose only.
     return DateTime.now().toDate().toString();;
  }
}

于 2019-03-22T17:43:24.513 回答
-1

制作一个每天运行的 cron 作业并为您的集合生成新名称并执行以下代码。在这里,我正在使用MongoDatabse而不是通过使用MongoNamespace我们可以重命名集合来获取集合。要获取旧/新集合名称,您可以编写一个单独的方法。

@Component
public class RenameCollectionTask {

  @Scheduled(cron = "${cron}")
  public void renameCollection() {

    // creating mongo client object
    final MongoClient client = new MongoClient(HOST_NAME, PORT);
    // selecting the mongo database
    final MongoDatabase database = client.getDatabase("databaseName");
    // selecting the mongo collection
    final MongoCollection<Document> collection = database.getCollection("oldCollectionName");
    // creating namespace
    final MongoNamespace newName = new MongoNamespace("databaseName", "newCollectionName");
    // renaming the collection
    collection.renameCollection(newName);
    System.out.println("Collection has been renamed");
    // closing the client
    client.close();
  }
}

要指定集合的​​名称,您可以参考,这样就不需要每次重新启动。

renameCollection()方法有以下限制:
1) 它不能在数据库之间移动集合。
2) 不支持sharded collections
3) 您不能重命名views.
有关详细信息,请参阅

于 2019-03-22T09:14:23.153 回答