Co próbuję zrobić, to pobrać listę plików GridFS, wysyłając zapytanie do pola z metadanymi. Na przykład mam dokument plików GridFS patrząc jak:Zapytanie dotyczące metadanych GridFS w MongoDB (Java)
{ "_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"}}
I chcę zapytać wszystkie pliki zawierające „target_field” = „ABCDEFG”. Tworzę zapytanie następująco:
BasicDBObject query = new BasicDBObject("metadata", new BasicDBObject("target_field", "abcdefg"));
// gridFS Object Initialization skipped
List<GridFSDBFile> files = gridFs.find(query);
Lista jest zawsze dobrze pusta. W przeciwnym razie zapytanie o nazwę pliku lub uploadDate działa idealnie. Czy nie można uzyskać plików GridFS według zagnieżdżonych atrybutów?
Czyżby pan błędnie coś? Działa to dobrze na moim komputerze. Używam mongod 2.0.4 i v2.7.3 dla sterownika Java. – Ren