Rumah > Artikel > pangkalan data > Bagaimana untuk Mendapatkan Masa Lawatan Terkini untuk Setiap Pengguna Unik dalam MySQL dengan ActiveRecord?
Apabila berurusan dengan data yang besar, selalunya perlu untuk mengekstrak maklumat unik semasa menjalankan operasi pangkalan data. Satu senario sedemikian ialah mengenal pasti lawatan terbaharu setiap pengguna yang berbeza.
Soalan:
Semasa cuba mendapatkan semula masa lawatan terkini untuk setiap pengguna unik menggunakan DISTINCT ON sintaks, ralat ActiveRecord::StatementInvalid ditemui. Pertanyaan yang digunakan ialah:
<code class="ruby">Event.order(time: :desc).select('DISTINCT ON(user_id) user_id, time')</code>
Penyelesaian:
Sintaks DISTINCT ON adalah khusus untuk PostgreSQL dan tidak digunakan untuk MySQL. Untuk mencapai hasil yang diingini dalam MySQL menggunakan ActiveRecord, pertanyaan harus diubah suai:
<code class="ruby">Events.group(:user_id).maximum(:time)</code>
Output:
Pertanyaan yang diubah suai ini akan menghasilkan output yang dijangkakan, di mana kunci mewakili ID pengguna unik, dan nilai mewakili masa lawatan terbaharu mereka:
{21=>Tue, 18 Dec 2018 11:15:24 UTC +00:00, 23=>Thu, 20 Dec 2018 06:42:10 UTC +00:00}
Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Masa Lawatan Terkini untuk Setiap Pengguna Unik dalam MySQL dengan ActiveRecord?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!