Menyiasat Rekod Pangkalan Data Dikumpulkan Mengikut Hari Menggunakan Laravel Eloquent
Apabila bekerja dengan pangkalan data, selalunya perlu mengagregatkan data mengikut selang waktu tertentu, seperti hari. Dalam kes Laravel Eloquent, kaedah groupBy() membenarkan kami melakukan pengumpulan sedemikian, tetapi lajur berasaskan masa seperti created_at mungkin menimbulkan cabaran apabila menggunakan kaedah ini.
Masalah: Pengumpulan mengikut hari mempertimbangkan saat
Isu ini timbul kerana lajur create_at biasanya termasuk jam, minit dan saat, menghasilkan cap masa yang berbeza untuk acara yang berlaku pada hari yang sama. Akibatnya, apabila mengumpulkan mengikut create_at, rekod untuk hari yang sama mungkin diasingkan kerana perbezaan masa.
Sebagai contoh, pertimbangkan sampel data berikut:
created_at | page_id | user_id |
---|---|---|
2023-10-11 01:02:03 | 3 | 1 |
2023-10-12 12:34:56 | 5 | 5 |
2023-10-13 15:47:12 | 5 | 2 |
2023-10-13 18:23:09 | 3 | 4 |
Jika kami mencuba untuk mengumpulkan data ini dengan create_at menggunakan perintah Eloquent:
<code class="php">$visitorTraffic = PageView::groupBy('created_at')->get();</code>
Kami akan mempunyai baris yang berasingan untuk setiap kali pelawat mengakses halaman pada hari tertentu, yang bukan hasil yang diingini.
Penyelesaian: Menggunakan Pertanyaan Mentah dan Tarikh Karbon
Untuk mengatasi isu ini, satu penyelesaian ialah menggunakan pertanyaan SQL mentah. Dalam MySQL, fungsi DATE() boleh digunakan untuk menukar cap masa kepada tarikh yang sepadan, membolehkan kami mengumpulkan mengikut hari tanpa mengambil kira komponen masa. Pertanyaan berikut boleh digunakan:
<code class="sql">DB::table('page_views') ->selectRaw('DATE(created_at) AS date, COUNT(*) AS views') ->groupBy('date') ->get();</code>
Sebagai alternatif, pendekatan yang lebih Laravel Eloquent-centric boleh digunakan menggunakan tarikh Carbon:
<code class="php">$visitorTraffic = PageView::where('created_at', '>=', Carbon::now()->subMonth()) ->groupBy(DB::raw('DATE(created_at)')) ->orderBy('date', 'DESC') ->get([ DB::raw('DATE(created_at) AS date'), DB::raw('COUNT(*) AS views') ]);</code>
Dengan menggunakan fungsi DATE() atau Carbon tarikh, kami boleh mengumpulkan rekod pangkalan data mengikut hari sambil memastikan rekod yang mewakili hari yang sama diagregatkan bersama.
Atas ialah kandungan terperinci Bagaimana untuk Menghimpunkan Rekod Pangkalan Data mengikut Hari Menggunakan Laravel Eloquent?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!