查询MongoDB GridFS元数据(Java)

我正在尝试通过查询元数据字段来获取GridFS文件列表。例如,我得到了一个GridFS文件文档,看起来像:

{ "_id" : { "$oid" : "4f95475f5ef4fb269dbac954"} , "chunkSize" : 262144 , "length" : 3077 , "md5" : "f24ea7ac05c5032f08808c6faabf413b" , "filename" : "file_xyz.txt" , "contentType" :  null  , "uploadDate" : { "$date" : "2012-04-23T12:13:19.606Z"} , "aliases" :  null  , "metadata" : { "target_field" : "abcdefg"}}

我想查询所有包含“ target_field” =“ abcdefg”的文件。我创建查询如下:

BasicDBObject query = new BasicDBObject("metadata", new BasicDBObject("target_field", "abcdefg"));

// gridFS Object Initialization skipped

List<GridFSDBFile> files = gridFs.find(query);

该列表始​​终为空。否则,查询文件名或uploadDate的效果很好。是否可以通过嵌套属性获取GridFS文件?

回答:

不幸的是,我没有让它与嵌套的BasicDBObjects一起使用。

最终,我使用了可以正常工作的点符号:

// This query fetches the files I need

BasicDBObject query = new BasicDBObject("metadata.target_field", "abcdefg"));

List<GridFSDBFile> files = gridFs.find(query);

以上是 查询MongoDB GridFS元数据(Java) 的全部内容, 来源链接: utcz.com/qa/416873.html

回到顶部