使用find() - 使用投影

时间:2017-07-03 22:17:21

标签: java mongodb projection mongodb-java data-retrieval

我正在使用mongodb java driver 3.4。

在mongodb数据库中,文档按照以下结构保存:

{
    "_id" : ObjectId("595a9fc4fe3f36402b7edf0e"),
    "id" : "123",
    "priceInfo" : [
        {object1: value1}, {object2: value2}, {object3: value3}
    ]
}

为了检索具有特定id的文档的“priceInfo”--Array,我编写了以下代码:

collection.find(eq("id", id)).first().projection(fields(include("priceInfo"), excludeId()));

我也根据文档编写了这段代码,你可以在这里找到:

http://mongodb.github.io/mongo-java-driver/3.4/javadoc/?com/mongodb/client/model/Projections.html

问题是我的IDE不接受此代码。

它给了我以下错误指示:

enter image description here

我不知道为什么这段代码不起作用。起初IDE建议包括几个类 - 我做了。但在那之后我仍然有一个错误指示,即你在上面看到的那个。

代码有什么问题?如何检索ID为ID的文档的priceInfo数组?

********* UPDATE ************** ********************

根据要求,这是全班:

package DatabaseAccess;

import Models.GasStation;
import com.mongodb.MongoClient;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;
import static com.mongodb.client.model.Filters.eq;
import static com.mongodb.client.model.Projections.excludeId;
import static com.mongodb.client.model.Projections.fields;
import static com.mongodb.client.model.Projections.include;
import com.mongodb.client.model.Updates;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.logging.Level;
import org.bson.Document;


public class databaseAccess {

    private final String DB_HOST = "localhost"; 
    private final int DB_PORT = 27017;
    private final String DB_NAME = "db1"; 
    private final String DB_COLLECTION = "prices"; 
    private final MongoClient mongoClient;
    private final MongoDatabase database;
    private final MongoCollection<Document> collection; 

    public databaseAccess(){
        mongoClient = new MongoClient(DB_HOST, DB_PORT);
        database = mongoClient.getDatabase(DB_NAME);
        collection = database.getCollection(DB_COLLECTION);
    }


    public String readFromDB(String id){
        collection.find(eq("id", id)).first().projection(fields(include("priceInfo"), excludeId()));
        return null;     
    }

}

1 个答案:

答案 0 :(得分:3)

您正在使用方法中的一系列调用进行操作。 让我们分析链中的每个元素:

  

MongoCollection:

     

FindIterable&LT; TDocument&GT; find() - 查找集合中的所有文档。

返回类型为FindIterable<TDocument>,您在链中调用下一个方法:

  

FindIterable&LT; TDocument&GT;

     

从com.mongodb.async.client.MongoIterable接口继承的方法:

     

batchCursor,首先是forEach,into,map

好的,我们将MongoIterable

  

MongoIterable&LT; TResult&GT;:

     

void first(SingleResultCallback callback) - Helper返回迭代器中的第一个项或null。

这意味着first(...)什么都没有返回。您从零开始调用projection(...),当然这不适用,因此编译器会将此标记为错误。

要调用projection(Bson projection),您应该有FindIterable<T>个实例。 MongoCollection.find()可以为您提供此实例:

collection.find(eq("id", id)).projection(fields(include("priceInfo"), excludeId()));