索引mongodb json文件java驱动
我在一个名为GOT的mongo db集合中有几个下面的json文档,我想索引GOT集合中每个文档中的嵌套数组metaTag数组元素。索引mongodb json文件java驱动
我曾尝试以下:
BasicDBObject index = new BasicDBObject("season.questions.questionEntry.metaTags",1);
mongoColl.createIndex(index);
我不知道,如果这点表示法是确定的json文件索引元素中的正确方法是什么? 如何判断索引是否成功创建?
编辑:加入我的查询:
// Query our collection documents metaTag elements for a matching string
// @SuppressWarnings("deprecation")
public void queryMetaTags(String query)
{
// Query to search all documents in current collection
List<String> continentList = Arrays.asList(new String[]{query});
DBObject matchFields = new
BasicDBObject("season.questions.questionEntry.metaTags",
new BasicDBObject("$in", continentList));
DBObject groupFields = new BasicDBObject("_id", "$_id").append("questions",
new BasicDBObject("$push","$season.questions"));
//DBObject unwindshow = new BasicDBObject("$unwind","$show");
DBObject unwindsea = new BasicDBObject("$unwind", "$season");
DBObject unwindepi = new BasicDBObject("$unwind", "$season.questions");
DBObject match = new BasicDBObject("$match", matchFields);
DBObject group = new BasicDBObject("$group", groupFields);
@SuppressWarnings("deprecation")
AggregationOutput output =
mongoColl.aggregate(unwindsea,unwindepi,match,group);
String jsonString = null;
JSONObject jsonObject = null;
jsonResultsArray = null;
ourResultsArray = new ArrayList<JSONObject>();
// Loop for each document in our collection
for (DBObject result : output.results())
{
try
{
// Parse our results so we can add them to an ArrayList
jsonString = JSON.serialize(result);
jsonObject = new JSONObject(jsonString);
jsonResultsArray = jsonObject.getJSONArray("questions");
// Put each of our returned questionEntry elements into an ArrayList
for (int i = 0; i < jsonResultsArray.length(); i++)
{
System.out.println("jsonResultsArray element (" + i + "): " + jsonResultsArray.getJSONObject(i).toString());
ourResultsArray.add(jsonResultsArray.getJSONObject(i));
//System.out.println("ourResultsArray element (" + i + "): " + ourResultsArray.get(i).toString());
}
}
catch (JSONException e1)
{
e1.printStackTrace();
}
}
}
您可以使用下面的Java代码索引所需的关键:
Mongo mongo = new Mongo("localhost", 27017);
DB db = mongo.getDB("dbName"); //set dbname name here
DBCollection collection = db.getCollection("collectionName");
collection.createIndex(new BasicDBObject("season.questions.questionEntry.metaTags",1));
Here是关于索引的详细信息。
@ Vishwas感谢您的答复,因为我不确定点符号是正确的用法。有一个问题,尽管在我的文档中尝试了这种索引方法(请参阅上面的链接示例),但是没有性能差异!所以我想知道这是否正常工作? – TripVoltage
性能取决于您用于索引和查询的字段。您需要在正确的字段上创建索引以提高性能。您可以在查询中使用'.explain(“executionStats”)'来获取有关索引使用的详细信息。例如'db.collection.find({你的查询})。explain(“executionStats”)' – Vishwas
我已经添加了我的复杂查询并且不知道如何使用这种类型的查询产生执行统计信息? – TripVoltage
[用MongoDb创建索引]的可能重复(http://stackoverflow.com/questions/14006294/create-an-index-with-mongodb) – ka4eli