Bagaimana untuk Mendapatkan Lawatan Terkini Semua Pengguna Unik dalam MySQL ActiveRecord?

Susan Sarandon
Lepaskan: 2024-10-31 01:02:29
asal
529 orang telah melayarinya

How to Get the Latest Visits of All Unique Users in MySQL ActiveRecord?

Cara Menggunakan Setara dengan DISTINCT ON dalam MySQL ActiveRecord

Keperluan adalah untuk mendapatkan semula lawatan terkini semua pengguna yang berbeza daripada acara meja. Menggunakan klausa DISTINCT ON(user_id) dengan MySQL dalam ActiveRecord menghasilkan ralat sintaks.

Persamaan MySQL dengan DISTINCT ON ialah menggunakan GROUP BY dengan fungsi MAX():

<code class="ruby">Events.group(:user_id).maximum(:time)</code>
Salin selepas log masuk

Pertanyaan ini akan mengumpulkan hasil mengikut user_id dan mengembalikan nilai maksimum untuk lajur masa untuk setiap kumpulan. Output akan menjadi cincang dengan user_id sebagai kunci dan masa lawatan terkini sebagai nilai:

{
  21 => "2018-12-18 09:44:59",
  42 => "2018-12-19 12:08:59"
}
Salin selepas log masuk

Nota: DISTINCT ON(columns) ialah sintaks khusus PostgreSQL. MySQL tidak menyokong sintaks ini secara langsung.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Lawatan Terkini Semua Pengguna Unik dalam MySQL ActiveRecord?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!