Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mencari Berbilang Kata Kunci Merentasi Berbilang Lajur dengan Susunan Berdasarkan Perkaitan dalam Laravel?

Bagaimana untuk Mencari Berbilang Kata Kunci Merentasi Berbilang Lajur dengan Susunan Berdasarkan Perkaitan dalam Laravel?

Linda Hamilton
Linda Hamiltonasal
2024-11-06 14:09:02722semak imbas

How to Search for Multiple Keywords Across Multiple Columns with Relevance-Based Ordering in Laravel?

Laravel: Mencari Berbilang Kata Kunci Berbanding Berbilang Lajur dengan Susunan Berdasarkan Relevan

Dalam Laravel, melaksanakan carian yang mempertimbangkan berbilang kata kunci terhadap berbilang lajur sambil mengekalkan perkaitan boleh menjadi mencabar. Artikel ini menangani masalah sedemikian, di mana hasil carian disusun berdasarkan kekerapan kejadian kata kunci dalam lajur yang ditentukan.

Senario:

Bar carian memerlukan tiga kata kunci sebagai input dan kriteria carian ialah:

  1. Baris yang mengandungi ketiga-tiga kata kunci dalam kedua-dua lajur (meta_name dan meta_description) didahulukan.
  2. Baris yang mengandungi hanya dua kata kunci pertama dalam lajur yang disebut berada di tempat kedua.
  3. Baris yang mengandungi hanya kata kunci pertama dalam lajur yang disebut di tempat ketiga.

Pertanyaan Pangkalan Data:

Untuk mencapai hasil yang diingini, pertanyaan pangkalan data harus menggabungkan berbilang keadaan ATAU dan menggunakan fungsi whereNotIn untuk mengecualikan baris yang telah diambil dalam keadaan sebelumnya.

<code class="php">$word1 = 'word1';
$word2 = 'word2';
$word3 = 'word3';

$all = DB::table('posts')
    ->where('meta_name', 'like', "%{$word1}%")
    ->where('meta_name', 'like', "%{$word2}%")
    ->where('meta_name', 'like', "%{$word3}%")
    ->orWhere(function($query) use ($word1, $word2, $word3) {
        $query->where('meta_description', 'like', "%{$word1}%")
              ->where('meta_description', 'like', "%{$word2}%")
              ->where('meta_description', 'like', "%{$word3}%");
    });

$twoWords = DB::table('posts')
    ->where('meta_name', 'like', "%{$word1}%")
    ->where('meta_name', 'like', "%{$word2}%")
    ->orWhere(function($query) use ($word1, $word2) {
        $query->where('meta_description', 'like', "%{$word1}%")
              ->where('meta_description', 'like', "%{$word2}%");
    })
    ->whereNotIn('id', $all->pluck('id'));

$oneWord = DB::table('posts')
    ->where('meta_name', 'like', "%{$word1}%")
    ->orWhere('meta_description', 'like', "%{$word1}%")
    ->whereNotIn('id', $all->pluck('id'))
    ->whereNotIn('id', $twoWords->pluck('id'));</code>

Kesatuan dan Susunan:

Akhir sekali, hasil $all, $twoWords dan $oneWord digabungkan menggunakan fungsi kesatuan untuk mendapatkan hasil carian tersusun.

<code class="php">$posts = $all->union($twoWords)->union($oneWord)->get(); // check this first

# or

$posts = $all->union($twoWords)->union($oneWord)->skip($start)->take($this->rowperpage)->get();</code>

Pendekatan ini memastikan hasil carian disusun mengikut kriteria yang ditentukan, bermula dengan baris yang mengandungi ketiga-tiga kata kunci dalam lajur yang ditentukan.

Atas ialah kandungan terperinci Bagaimana untuk Mencari Berbilang Kata Kunci Merentasi Berbilang Lajur dengan Susunan Berdasarkan Perkaitan dalam Laravel?. 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