1

我正在使用 mongoDB 和 Java SpringData 开发一个日志寄存器。

这里MongoDb capped sub-collection讨论了 mongoDB 结构,但我会使用 Java。最重要的是我有一个包含一个或多个字段和一个上限数组的文档。

Java中有一些方法或方法可以做到这一点吗?

我的对象是这样的:

user = {
   name: String,
   latest_messages: [String] (capped to a 100 elements)
}

在 Java 中:

public class MessageLog {
    private ObjectId id;
    private String name;
    private List<Message> messages;
}

在哪里:

public class Message{
    private String text;
    private String level;
    private Date date;
}

编辑

我正在使用带有 Spring 源的 Java(mongodb 驱动程序 v2.10.1:http ://central.maven.org/maven2/org/mongodb/mongo-java-driver/2.10.1/ )

4

2 回答 2

1

我终于得到了使用此代码的解决方案:

// Define the search query
BasicDBObject searchQuery = new BasicDBObject().append("idU", idUser);

// To create the json query to modify
BasicDBObject logDocument = new BasicDBObject();

// Create the object and add it to a list (because the $each require a list)
List<DBObject> list = new ArrayList<DBObject>();
DBObject object = new BasicDBObject().append("text", logMessage.getText());
object.append("level", logMessage.getLevel())
object.append("date", logMessage.getDate());
list.add(object);

// Create the $sort and $slice query at the same time
logDocument.append(
    "$push",
    new BasicDBObject().append("logs", new BasicDBObject().append("$each", list).append("$sort", new BasicDBObject().append("date", 1))
            .append("$slice", -10)));

String json = "{findAndModify:\"collectionLog\", query:" + searchQuery.toString() + ", update: " + logDocument.toString() + ", upsert:true}";

try {
     getMongoTemplate().executeCommand(json);
} catch (Exception e) {
     System.out.println(e);
}

我希望它对其他人有用!!!

于 2013-04-18T09:37:26.253 回答
0

如您所见,MongoDB 无法提供此功能,因此必须在应用层解决。

默认情况下,Java 不支持任何像封顶集合一样工作的东西。但是Apache Commons 项目的集合库有CircularFiFoBuffer类,这似乎是您需要的。您使用最大尺寸创建它。当您添加一个新元素并且它已经达到最大尺寸时,最旧的元素将被丢弃。迭代顺序是从最旧的元素到最新的元素。

没有外部库的解决方法可以使用LinkedList完成。使用 addFirst() 方法添加新元素,检查大小,当它大于所需的最大大小时,调用 removeLast()。

于 2013-04-16T13:37:18.297 回答