Aggregation MongoDBでは集計のために Aggregation という仕組みが用意されているのですよ。すわ!便利。 例として、WebShopsコレクション(≒テーブル)に各Web店舗のアクセス数が日単位で記録されているものとし、ここ一週間のアクセスランキングを取得してみます。 PHPでのサンプルコードは下記のようになります。 // MongoDBへ接続 $mongo = new Mongo(); // MyDBデータベース $db = $mongo->selectDB('mydb'); // WebShopsコレクション(≒テーブル) $collShops = $db->selectCollection("webshops"); // ここ一週間でのWebアクセスが多い順に店舗を取得 $docs = $collShops->aggregate( array( // $mat
![MongoDBで集計(Aggregate) - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/445d8d6d0b3fc9db00de693a11d7b2ae739ceced/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9TW9uZ29EQiVFMyU4MSVBNyVFOSU5QiU4NiVFOCVBOCU4OCVFRiVCQyU4OEFnZ3JlZ2F0ZSVFRiVCQyU4OSZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnR4dC1jbGlwPWVsbGlwc2lzJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9NTUyYjBiYWU3ZDNlMTFlYWRmM2Y4NDY4ODk0Zjc1NzI%26mark-x%3D142%26mark-y%3D112%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQweWFzdW1vZGV2JnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz1hZGVmYjFjYWYyMmRmM2Q0ZTE2MDg4NGE0ZTg3MjExNg%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3D290f305cc4d2a4dca9f7cc46ce3cb700)