Bagaimanakah saya boleh mengisih hasil carian teks penuh MySQL mengikut perkaitan?

DDD
Lepaskan: 2024-11-03 02:19:29
asal
969 orang telah melayarinya

How can I sort MySQL fulltext search results by relevancy?

Mengisih Hasil Carian Teks Penuh MySQL mengikut Relevan

Apabila bekerja dengan MySQL, adalah penting untuk memahami perbezaan antara carian LIKE dan teks penuh untuk pengisihan hasil yang tepat.

Dalam pertanyaan yang disediakan:

$query="SELECT * from `vocabulary` WHERE translation = 'word' OR translation LIKE '%word%'";
Salin selepas log masuk

Pengendali LIKE digunakan untuk padanan separa, bukan carian teks penuh. Untuk melakukan carian teks penuh, gunakan sintaks MATCH(...) AGAINST(...).

Contohnya:

$query="SELECT * from `vocabulary` WHERE MATCH(translation) AGAINST('+word')";
Salin selepas log masuk

Fungsi MATCH mengembalikan skor padanan yang boleh digunakan sebagai anggaran perkaitan. Skor ini boleh digunakan untuk menyusun keputusan. Contohnya:

$query="SELECT *, MATCH(translation) AGAINST('+word') AS score FROM `vocabulary` ORDER BY score DESC";
Salin selepas log masuk

Pertanyaan ini mengisih keputusan mengikut perkaitan, dengan perlawanan yang mendapat markah tertinggi muncul dahulu.

Atas ialah kandungan terperinci Bagaimanakah saya boleh mengisih hasil carian teks penuh MySQL mengikut perkaitan?. 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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan