day*_*mer 4 java mongodb mongo-java
我有一个JUnit rule称为MongoRule样子
public class MongoRule extends ExternalResource {
private static final Logger LOGGER = LoggerFactory.getLogger(MongoRule.class);
private final MongoService mongoService;
public MongoRule() throws UnknownHostException {
mongoService = new MongoService(getConfiguredHost(), getConfiguredPort(), getConfiguredDatabase());
}
@Override
protected void before() throws Throwable {
LOGGER.info(" Setting up Mongo Database - " + getConfiguredDatabase());
}
@Override
protected void after() {
LOGGER.info("Shutting down the Mongo Database - " + getConfiguredDatabase());
mongoService.getMongo().dropDatabase(getConfiguredDatabase());
}
@Nonnull
public DB getDatabase() {
return mongoService.getMongo().getDB(getConfiguredDatabase());
}
@Nonnull
public Mongo getMongo() {
return mongoService.getMongo();
}
@Nonnull
public MongoService getMongoService() {
return mongoService;
}
public static int getConfiguredPort() {
return Integer.parseInt(System.getProperty("com.db.port", "27017"));
}
@Nonnull
public static String getConfiguredDatabase() {
return System.getProperty("com.db.database", "database");
}
@Nonnull
public static String getConfiguredHost() {
return System.getProperty("com.db.host", "127.0.0.1");
}
}
Run Code Online (Sandbox Code Playgroud)
然后我尝试插入一些文件如下
public static void saveInDatabase() {
LOGGER.info("preparing database - saving some documents");
mongoRule.getMongoService().putDocument(document1);
mongoRule.getMongoService().putDocument(document2);
}
Run Code Online (Sandbox Code Playgroud)
凡document1和document2有效DBObject证件.架构看起来像
{
Id: 001
date_created: 2012-10-31
vars: {
'1': {
name: n1
value:v1
}
'2': {
name: n2
value:v2
}
'3': {
name: n3
value:v3
}
}
{
Id: 002
date_created: 2012-10-30
vars: {
'1': {
name: n4
value:v4
}
'2': {
name: n5
value:v5
}
'3': {
name: n6
value:v6
}
}
Run Code Online (Sandbox Code Playgroud)
现在我尝试查询集合并获取这些对象,所以我这样做
public static void getDocuments(List<String> documentIds) {
BasicDBList docIds = new BasicDBList();
for (String docId: documentIds) {
docIds.add(new BasicDBObject().put("Id", docId));
}
DBObject query = new BasicDBObject();
query.put("$in", docIds);
DBCursor dbCursor = mongoRule.getDatabase().getCollection("mycollection").find(query);
System.out.println(dbCursor == null);
if (dbCursor != null) {
while (dbCursor.hasNext()) {
System.out.println("object - " + dbCursor.next());
}
}
}
Run Code Online (Sandbox Code Playgroud)
mycollection是所有文档持久化的集合,它来自外部服务.
当我运行此文档时,我看到以下内容
preparing database - saving some documents
inserting document - DBProposal # document1
inserting document - DBProposal # document2
false
Run Code Online (Sandbox Code Playgroud)
这意味着collection.find()找不到这些文件.
我在这里做的不是什么?我该如何取回文件?
我很新的使用Java与Mongo和使用该参考构造查询
更新
在更改构造查询的方式后,我仍然看不到文档
public static void getDocuments(List<String> documentIds) {
BasicDBList docIds = new BasicDBList();
docIds.addAll(documentIds)
DBObject query = new BasicDBObject();
query.put("$in", docIds);
DBCursor dbCursor = mongoRule.getDatabase().getCollection("mycollection").find(query);
System.out.println(dbCursor == null);
if (dbCursor != null) {
while (dbCursor.hasNext()) {
System.out.println("object - " + dbCursor.next());
}
}
}
Run Code Online (Sandbox Code Playgroud)
并通过返回集合名称
private static String getCollectionName(@Nonnull final DBObject dbObject) {
return "mycollection";
}
Run Code Online (Sandbox Code Playgroud)
你现在正在做相当于:
db.col.find({$in:[{Id:id1}, {Id:id2}, ..., {Id:idN}]})
Run Code Online (Sandbox Code Playgroud)
这不是一个有效的查询,因为您没有指定$ in in的字段.我假设你想要:
db.col.find({Id:{$in:[id1, id2, ..., idN]}})
Run Code Online (Sandbox Code Playgroud)
相应地更改您的查询构造代码,您应该没问题.
编辑:添加正确的代码:
public static void getDocuments(List<Integer> documentIds) {
BasicDBList docIds = new BasicDBList();
docIds.addAll(documentIds)
DBObject inClause = new BasicDBObject("$in", docIds);
DBObject query = new BasicDBObject("Id", inClause);
DBCursor dbCursor = mongoRule.getDatabase().getCollection("mycollection").find(query);
System.out.println(dbCursor == null);
if (dbCursor != null) {
while (dbCursor.hasNext()) {
System.out.println("object - " + dbCursor.next());
}
}
}
Run Code Online (Sandbox Code Playgroud)
请注意,这假设"Id"不是"_id"
| 归档时间: |
|
| 查看次数: |
12807 次 |
| 最近记录: |