こんにちは、Mongo db フィールドは次のとおりです。
"_id" : ObjectId("51d582be7a8d51bd29ca78a3"),
"Filename" : "sample.pdfe",
"Title" : null,
"Author" : null,
"ContentType" : "application/x-msdownload; format=pe32",
"url" : "Z:sample.pdf",
"Keywords" : ["php","java",".net","python"]
以下は、インデックス付きフィールドで全文検索を行うための私のコードです
m = new Mongo("10.0.0.26", 27017);
DB db = m.getDB("soft") ;
DBCollection col = db.getCollection("metadatanew") ;
String collection = col.toString();
DBObject searchCmd = new BasicDBObject();
searchCmd.put("text", collection);
searchCmd.put("search", name);
CommandResult commandResult = db.command(searchCmd);
BasicDBList results = (BasicDBList)commandResult.get("results");
for (Iterator <Object> it = results.iterator();it.hasNext();)
{
BasicDBObject result = (BasicDBObject) it.next();
BasicDBObject dbo = (BasicDBObject) result.get("obj");
System.out.println(dbo.getString("Filename"));
}
以下のコマンドを使用して、2 つのフィールドにテキスト インデックスを作成しました。
db.metadatanew.ensureIndex({'Filename':"text"}, {'Keywords':"text"})
ファイル名とキーワードでテキスト インデックスを作成しましたが、ファイル名のみで全文検索を行うことができます。コードに問題はありますか。助けてください