Bismillaahirrohmaanirrohiim…
Pada MySQL, untuk menjalankan query group by dan count atau sum caranya cukup mudah, bisa dengan query di bawah ini:
select kolomA, count(kode) as jumkode from tabel where status='oke' group by kolomA order by jumkode DESC
Jika pada mongoDB, menggunakan fungsi aggregate
db.namacollection.aggregate([{ $match: { status: "oke" } },{"$group": {_id: "$kolomA",count: {$sum: 1}}},{$sort: {count: -1}}])
Jika menggunakan php driver mongoDB, perintahnya seperti berikut
$manager = new MongoDB\Driver\Manager(); $command = new MongoDB\Driver\Command([ 'aggregate' => 'namacollection', 'pipeline' => [ ['$match'=>['status'=>'oke']], ['$group' => ['_id' => '$kolomA', 'count' => ['$sum' => 1]]], ['$sort'=>['count'=>-1]], ], 'cursor' => new stdClass, ]); $cursor = $manager->executeCommand('namadatabase', $command);
Nah, sekarang jika ingin memberi filter range tanggal dari tanggal sekian sampai tanggal sekian, perintah di mongoDB nya sebagai berikut:
db.namacollection.aggregate([{ $match: { tanggal: {$gte:ISODate("2021-05-01"),$lt:ISODate("2020-05-30"}} } },{"$group": {_id: "$kolomA",count: {$sum: 1}}},{$sort: {count: -1}}]) //$gte bisa diganti $gt kalau error
Versi phpnya adalah seperti di bawah ini:
$manager = new MongoDB\Driver\Manager(); $command = new MongoDB\Driver\Command([ 'aggregate' => 'namacollection', 'pipeline' => [ ['$match'=>['tanggal'=> [ '$gt'=>new MongoDB\BSON\UTCDatetime(strtotime('2021-05-01 00:00:00') * 1000), '$lt'=>new MongoDB\BSON\UTCDatetime(strtotime('2020-05-30 23:59:59') * 1000), ] ] ], ['$group' => ['_id' => '$kolomA', 'count' => ['$sum' => 1]]], ['$sort'=>['count'=>-1]], ], 'cursor' => new stdClass, ]); $cursor = $manager->executeCommand('namadatabase', $command); //format kolom tanggal haruslah berupa datetime
Demikian, semoga bermanfaat…
Bismillaahirrohmaanirrohiim... Saat ini teknologi sudah berkembang cepat, ada kalanya kita ingin diberikan informasi secara cepat…
Bismillaahirrohmaanirrohiim... Jika web diakses oleh banyak orang, khususnya yang berbasis wordpress, maka secara normal proses…
Bismillaahirrohmaanirrohiim... Saat ini, sekolah baik SD, SMP, ataupun SMA tentunya ingin dapat melihat dan memonitor…
Bismillaahirrohmaanirrohiim... Pada artikel kali ini saya akan berbagi informasi tentang program pendataan pendukung calon legislatif…
Bismillaahirrohmaanirrohiim... Saat kita melakukan screenshot di browser chrome, pada windows 11 menyediakan fungsi yang bagus…
Bismillaahirrohmaanirrohiim... Untuk website yang ingin tidak muncul popup translate dari browser, bisa dicoba kode di…