Rumah  >  Artikel  >  pangkalan data  >  Bagaimanakah Saya Boleh Mendapatkan Data dalam Pesanan Tertentu dalam MySQL Tanpa Bergantung pada Nilai Medan?

Bagaimanakah Saya Boleh Mendapatkan Data dalam Pesanan Tertentu dalam MySQL Tanpa Bergantung pada Nilai Medan?

DDD
DDDasal
2024-10-30 07:12:02429semak imbas

 How Can I Retrieve Data in a Specific Order in MySQL Without Relying on a Field's Value?

Memelihara Susunan dalam Keputusan Pertanyaan: Penyelesaian

Dalam MySQL, mendapatkan semula data dalam susunan tertentu tanpa bergantung pada nilai medan tertentu boleh mencabar. Pertimbangkan senario berikut: memilih ID 7, 2, 5, 9 dan 8 sambil mengekalkan susunan yang tepat ini sebagai hasilnya.

Pendekatan tradisional menggunakan klausa IN, seperti yang ditunjukkan dalam contoh yang disediakan, tidak menjamin susunan yang dikehendaki. Walau bagaimanapun, penyelesaian menarik telah muncul yang memanfaatkan fungsi FIND_IN_SET:

SELECT id FROM table
WHERE id in (7, 2, 5, 9, 8)
ORDER BY FIND_IN_SET(id, "7,2,5,9,8");

Pertanyaan ini secara berkesan memberikan setiap ID kedudukan dalam urutan "7,2,5,9,8". Fungsi FIND_IN_SET mengembalikan kedudukan ID dalam urutan yang diberikan. Sebagai contoh, ID 7 berada pada kedudukan 1, ID 2 berada pada kedudukan 2 dan seterusnya.

Dengan mengisih keputusan mengikut output FIND_IN_SET, pertanyaan memastikan bahawa ID yang diambil sejajar dengan susunan yang ditentukan dalam hujah kedua. Penyelesaian rumit ini membolehkan pembangun mengenakan perintah yang telah ditetapkan pada hasil pertanyaan, membuka kemungkinan baharu untuk manipulasi data.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mendapatkan Data dalam Pesanan Tertentu dalam MySQL Tanpa Bergantung pada Nilai Medan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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