이 문서 에서는 집계 프레임워크 의 기능을 보여주는 여러 가지 실용적인 예제를 제공합니다.
The 우편번호 데이터 세트를 사용한 애그리게이션 예제에서는 미국의 모든 우편번호 및 인구에 대해 공개적으로 사용 가능한 데이터 세트 사용합니다. 이 데이터는 zips.json에서 확인할 수 있습니다.
요구 사항:
모두 설치되었는지 확인해 보겠습니다.
다음 명령을 사용하여 mongod 데이터 세트 를 mongod 인스턴스 에 로드합니다.
$ mongoimport --drop -d test -c zipcodes zips.json 
MongoDB shell 을 사용하여 모든 항목을 성공적으로 가져왔는지 확인하겠습니다.
$ mongo test connecting to: test > db.zipcodes.count() 29467 > db.zipcodes.findOne() {       "_id" : "35004",       "city" : "ACMAR",       "loc" : [               -86.51557,               33.584132       ],       "pop" : 6055,       "state" : "AL" } 
우편 번호 데이터 세트를 사용한 애그리게이션
이 컬렉션의 각 문서의 형식은 다음과 같습니다.
{   "_id" : "35004",   "city" : "Acmar",   "state" : "AL",   "pop" : 6055,   "loc" : [-86.51557, 33.584132] } 
이 문서에는 다음이 포함됩니다.
- _id필드에는 우편번호가 string 로 포함됩니다.
- 0} - city필드에는 도시 이름이 포함됩니다.
- state필드에는 두 글자의 상태 약어가 포함됩니다.
- 0} - pop필드에는 인구가 포함됩니다.
- loc필드는 위치를- [latitude, longitude]배열로 보유합니다.
인구 10 백만 이상의 주
인구가 10 백만 이상인 모든 주를 가져오려면 다음 집계 파이프라인을 사용합니다.
static void print_pipeline (mongoc_collection_t *collection) {    mongoc_cursor_t *cursor;    bson_error_t error;    const bson_t *doc;    bson_t *pipeline;    char *str;    pipeline = BCON_NEW ("pipeline",                         "[",                         "{",                         "$group",                         "{",                         "_id",                         "$state",                         "total_pop",                         "{",                         "$sum",                         "$pop",                         "}",                         "}",                         "}",                         "{",                         "$match",                         "{",                         "total_pop",                         "{",                         "$gte",                         BCON_INT32 (10000000),                         "}",                         "}",                         "}",                         "]");    cursor = mongoc_collection_aggregate (collection, MONGOC_QUERY_NONE, pipeline, NULL, NULL);    while (mongoc_cursor_next (cursor, &doc)) {       str = bson_as_canonical_extended_json (doc, NULL);       printf ("%s\n", str);       bson_free (str);    }    if (mongoc_cursor_error (cursor, &error)) {       fprintf (stderr, "Cursor Failure: %s\n", error.message);    }    mongoc_cursor_destroy (cursor);    bson_destroy (pipeline); } int main (void) {    mongoc_client_t *client;    mongoc_collection_t *collection;    const char *uri_string = "mongodb://localhost:27017/?appname=aggregation-example";    mongoc_uri_t *uri;    bson_error_t error;    mongoc_init ();    uri = mongoc_uri_new_with_error (uri_string, &error);    if (!uri) {       fprintf (stderr,                "failed to parse URI: %s\n"                "error message:       %s\n",                uri_string,                error.message);       return EXIT_FAILURE;    }    client = mongoc_client_new_from_uri (uri);    if (!client) {       return EXIT_FAILURE;    }    mongoc_client_set_error_api (client, 2);    collection = mongoc_client_get_collection (client, "test", "zipcodes");    print_pipeline (collection);    mongoc_uri_destroy (uri);    mongoc_collection_destroy (collection);    mongoc_client_destroy (client);    mongoc_cleanup ();    return EXIT_SUCCESS; } 
다음과 같은 결과가 표시됩니다.
{ "_id" : "PA", "total_pop" : 11881643 } { "_id" : "OH", "total_pop" : 10847115 } { "_id" : "NY", "total_pop" : 17990455 } { "_id" : "FL", "total_pop" : 12937284 } { "_id" : "TX", "total_pop" : 16986510 } { "_id" : "IL", "total_pop" : 11430472 } { "_id" : "CA", "total_pop" : 29760021 } 
위의 집계 파이프라인은 두 개의 파이프라인 연산자 $group 및 $match 로 빌드됩니다.
$group 파이프라인 연산자 에는 그룹화를 지정하는 _id 필드 가 필요합니다. 나머지 필드는 복합 값을 생성하는 방법을 지정하며 그룹 집계 함수 $addToSet, $first, $last, $max, $min, $avg, $push, $sum 중 하나를 사용해야 합니다. $match 파이프라인 연산자 구문은 읽기 작업 쿼리 구문과 동일합니다.
$group 프로세스 는 모든 문서를 읽고 각 상태 에 대해 별도의 문서 예시 만듭니다.
{ "_id" : "WA", "total_pop" : 4866692 } 
total_pop 필드 는 $sum 집계 함수를 사용하여 소스 문서에 있는 모든 팝 필드의 값을 합산합니다.
$group 에 의해 생성된 문서는 $match 파이프라인 연산자로 파이프됩니다. total_pop 필드 값이 10 백만 이상인 문서를 반환합니다.
주별 평균 도시 인구
도시당 평균 인구가 가장 높은 처음 3개 주를 가져오려면 다음 집계 을 사용합니다.
pipeline = BCON_NEW ("pipeline", "[",    "{", "$group", "{", "_id", "{", "state", "$state", "city", "$city", "}", "pop", "{", "$sum", "$pop", "}", "}", "}",    "{", "$group", "{", "_id", "$_id.state", "avg_city_pop", "{", "$avg", "$pop", "}", "}", "}",    "{", "$sort", "{", "avg_city_pop", BCON_INT32 (-1), "}", "}",    "{", "$limit", BCON_INT32 (3) "}", "]"); 
이 집계 파이프라인 은 다음을 생성합니다.
{ "_id" : "DC", "avg_city_pop" : 303450.0 } { "_id" : "FL", "avg_city_pop" : 27942.29805615551 } { "_id" : "CA", "avg_city_pop" : 27735.341099720412 } 
위의 집계 파이프라인은 세 개의 파이프라인 연산자 $group, $sort 및 $limit 로 빌드됩니다.
첫 번째 $group 연산자는 다음 문서를 생성합니다.
{ "_id" : { "state" : "WY", "city" : "Smoot" }, "pop" : 414 } 
$group 연산자는 _id 필드를 제외한 중첩 문서를 사용할 수 없습니다.
두 번째 $group 는 이러한 문서를 사용하여 다음 문서를 생성합니다.
{ "_id" : "FL", "avg_city_pop" : 27942.29805615551 } 
이러한 문서는 avg_city_pop 필드 를 기준으로 내림차순으로 정렬됩니다. 마지막으로 $limit 파이프라인 연산자 는 정렬된 설정하다 에서 첫 번째 3 문서를 반환합니다.