Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Isih Keputusan Dalam Kategori Selepas Menggunakan UNION dalam MySQL?

Bagaimanakah Saya Boleh Isih Keputusan Dalam Kategori Selepas Menggunakan UNION dalam MySQL?

Patricia Arquette
Lepaskan: 2025-01-11 11:43:44
asal
653 orang telah melayarinya

How Can I Sort Results Within Categories After Using UNION in MySQL?

Isih hasil pertanyaan UNION dalam MySQL

Apabila menggunakan operator UNION dalam MySQL untuk memproses data daripada berbilang sumber data, hasil pengisihan boleh menimbulkan cabaran, terutamanya apabila keputusan perlu diisih dalam kategori tertentu. Masalah ini biasanya berlaku apabila mengekstrak data daripada satu jadual berdasarkan kriteria yang berbeza (contohnya, penapisan jarak bagi pertanyaan carian).

Huraian Masalah

Dalam senario yang diberikan, tiga pertanyaan berasingan mengekstrak data berdasarkan keadaan jarak yang berbeza:

  1. Carian padanan tepat
  2. Jarak dalam 5 kilometer
  3. Jarak dalam 5-15 kilometer

Kemudian gunakan UNION untuk menggabungkan keputusan ini dan memaparkannya di bawah tajuk yang sesuai (contohnya, "Hasil tepat" dan "Hasil dalam jarak 5 kilometer"). Pengguna ingin mengisih hasil berdasarkan ID atau add_date, tetapi menambah klausa ORDER BY pada akhir pertanyaan gabungan mengisih semua hasil secara keseluruhan, mengabaikan keperluan untuk mengisih mengikut tajuk.

Penyelesaian menggunakan lajur pseudo Kedudukan

Untuk mengisih hasil dalam setiap kategori sambil menggabungkan hasil, anda boleh memperkenalkan lajur pseudo yang dipanggil "Kedudukan" dalam setiap pertanyaan pilihan. Lajur ini akan digunakan untuk mengisih mengikut sebelum mengisih mengikut kriteria sebenar. Kod berikut menggambarkan pendekatan ini:

<code class="language-sql">SELECT *
FROM (
    SELECT 1 AS Rank, id, add_date FROM Table WHERE <精确匹配条件>
    UNION ALL
    SELECT 2 AS Rank, id, add_date FROM Table WHERE distance < 5
    UNION ALL
    SELECT 3 AS Rank, id, add_date FROM Table WHERE distance BETWEEN 5 AND 15
) AS CombinedResults
ORDER BY Rank, id DESC, add_date DESC;</code>
Salin selepas log masuk

Dalam pertanyaan ini, lajur pseudo Kedudukan memberikan nilai 1, 2 dan 3 kepada tiga pertanyaan masing-masing. Klausa ORDER BY mengisih keputusan dahulu mengikut Kedudukan, kemudian mengikut ID dan add_date dalam tertib menurun. Pendekatan ini membolehkan anda mengisih hasil dalam setiap tajuk sambil mengekalkan perbezaan kategori.

Sila ambil perhatian bahawa <精确匹配条件> perlu diganti dengan kriteria carian padanan tepat anda. Penyelesaian ini menganggap jadual anda dinamakan Table dan mengandungi lajur id, add_date dan distance. Buat pelarasan yang sesuai berdasarkan struktur dan keadaan jadual sebenar anda.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Isih Keputusan Dalam Kategori Selepas Menggunakan UNION dalam MySQL?. 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