2013-02-10 2 views
5

MongoDB를 처음 사용하고 jsp/servlet을 사용하여 간단한 사이트를 만들어야합니다.MongoDB 자바 그룹/카운트 기능

사이트를 몇 번 방문했는지 계산하는 쿼리를 생성해야합니다. 방문 된 모든 페이지 등

page: localhost:8080/mongoProjekat/treca visited: n(times)<br> 
page: localhost:8080/mongoProjekat/druga visited: n(times) 

... 그리고 : 내가해야 할 것은 다음과 같이 보일 것입니다 결과는

{ "_id" : { "$oid" : "5117fa92f1d3a4093d0d3902"} , "ip" : "127.0.0.1" , "datum" : { "$date" : "2013-02-10T19:52:50.051Z"} , "odlaznaStr" : "localhost:8080/mongoProjekat/" , "dolaznaStr" : "localhost:8080/mongoProjekat/treca"}<br> 
{ "_id" : { "$oid" : "5117fa92f1d3a4093d0d3903"} , "ip" : "127.0.0.1" , "datum" : { "$date" : "2013-02-10T19:52:50.796Z"} , "odlaznaStr" : "localhost:8080/mongoProjekat/treca.jsp" , "dolaznaStr" : "localhost:8080/mongoProjekat/peta"}<br> 
{ "_id" : { "$oid" : "5117fa93f1d3a4093d0d3904"} , "ip" : "127.0.0.1" , "datum" : { "$date" : "2013-02-10T19:52:51.141Z"} , "odlaznaStr" : "localhost:8080/mongoProjekat/peta.jsp" , "dolaznaStr" : "localhost:8080/mongoProjekat/treca"}<br> 
{ "_id" : { "$oid" : "5117fa93f1d3a4093d0d3905"} , "ip" : "127.0.0.1" , "datum" : { "$date" : "2013-02-10T19:52:51.908Z"} , "odlaznaStr" : "localhost:8080/mongoProjekat/treca.jsp" , "dolaznaStr" : "localhost:8080/mongoProjekat/cetvrta"}<br> 
{ "_id" : { "$oid" : "5117fa94f1d3a4093d0d3906"} , "ip" : "127.0.0.1" , "datum" : { "$date" : "2013-02-10T19:52:52.035Z"} , "odlaznaStr" : "localhost:8080/mongoProjekat/treca.jsp" , "dolaznaStr" : "localhost:8080/mongoProjekat/cetvrta"}<br> 
{ "_id" : { "$oid" : "5117fa94f1d3a4093d0d3907"} , "ip" : "127.0.0.1" , "datum" : { "$date" : "2013-02-10T19:52:52.197Z"} , "odlaznaStr" : "localhost:8080/mongoProjekat/cetvrta.jsp" , "dolaznaStr" : "localhost:8080/mongoProjekat/treca"} 

:

내 DB는 다음과 같습니다 .

저는 Java를 사용하고 있습니다.

+0

이 한 번 봐 ['DBCollection.aggregate'] (http://api.mongodb.org/java/current/) 몽고의의 [집계 프레임 워크]에 대한 액세스를 제공합니다 : 나는이 방법을 수행 한 (http://docs.mongodb.org/manual/applications/aggregation/) 기능을 사용하여 이러한 쿼리를 처리 할 수 ​​있습니다. – JohnnyHK

답변

9

이 SQL을 MongoDB 차트 http://docs.mongodb.org/manual/reference/sql-aggregation-comparison/에게 유용하게 사용할 수 있습니다. 즉각적인 질문에 대해서는

:

// getCollection 

    DBCollection myColl = db.getCollection("toskebre"); 

    // for the $group operator 
    // note - the collection still has the field name "dolaznaStr" 
    // but, to we access "dolaznaStr" in the aggregation command, 
    // we add a $ sign in the BasicDBObject 

    DBObject groupFields = new BasicDBObject("_id", "$dolaznaStr"); 

    // we use the $sum operator to increment the "count" 
    // for each unique dolaznaStr 
    groupFields.put("count", new BasicDBObject("$sum", 1)); 
    DBObject group = new BasicDBObject("$group", groupFields); 


    // You can add a sort to order by count descending 

    DBObject sortFields = new BasicDBObject("count", -1); 
    DBObject sort = new BasicDBObject("$sort", sortFields); 


    AggregationOutput output = myColl.aggregate(group, sort); 

    System.out.println(output.getCommandResult()); 

println 메소드가 인쇄됩니다 : 대답 케이에 대한

{ "serverUsed" : "localhost/127.0.0.1:27017" , 
    "result" : [ { "_id" : "localhost:8080/mongoProjekat/treca" , "count" : 3} , 
       { "_id" : "localhost:8080/mongoProjekat/cetvrta" , "count" : 2} , 
       { "_id" : "localhost:8080/mongoProjekat/peta" , "count" : 1}] , 
    "ok" : 1.0} 
0

타이. 나는 이미 당신과 비슷한 해결책을 찾았습니다.

 DBObject match = new BasicDBObject("stranica","$dolaznaStr"); 
    DBObject project = new BasicDBObject("$project",match); 

    DBObject id = new BasicDBObject("_id",new BasicDBObject("stranica","$stranica")); 
    id.put("posete", new BasicDBObject("$sum", 1)); 
    DBObject group = new BasicDBObject("$group",id); 

    DBObject srt = new BasicDBObject("posete",-1); 
    DBObject sort = new BasicDBObject("$sort", srt); 
    AggregationOutput ao = collection.aggregate(project, group, sort);