Rumah > Artikel > pangkalan data > Bagaimana untuk Mencari Berbilang Kata Kunci Merentasi Berbilang Lajur dengan Susunan Berdasarkan Perkaitan dalam 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:
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!