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 errorVersi 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... Berikut ini adalah cara untuk memudahkan programmer dalam singkronisasi kode program dari laptop ke…
Bismillaahirrohmaanirrohiim... jika kita ingin mengarahkan semua domain apapun keserver utama, dengan menangkap hostname agar menjadi…
Bismillaahirrohmaanirrohiim... Untuk push data ke github, kadangkala kita lupa untuk set user dan email, berikut…
Bismillaahirrohmaanirrohiim... mitm adalah tools yang bisa menggantikan fiddler, untuk memantau trafik internet, dari website, aplikasi,…
Bismillaahirrohmaanirrohiim... berikut ini tambahan kode pada vhost nginx untuk memperbolehkan cors method options {{settings}} location…
Bismillaahirrohmaanirrohiim... Jika kita membuka login halaman cyberpanel dan tahu tahu muncul inputan kode authenticator, berikut…