ユーザーが質問を入力できる検索機能を作成すると、私のコードは、MySQL データベースに既にある質問とできるだけ多くの単語を照合し、一致する単語の量に応じて上位 5 つの結果を表示します。質問。
一致する単語の数をカウントする ) 関数を使用しますcount(
が、現時点では、50% 以上の単語が一致するデータベース内の最初の 5 つの結果として表示される結果が表示されます。結果を最初に最も一致するものとして表示し、データベース内のすべての結果について下に進みますが、上位5つだけを表示します.これが私が持っているコードです
<?php
include("config.php");
$search_term = filter_var($_GET["s"], FILTER_SANITIZE_STRING); //User enetered data
$search_term = str_replace ("?", "", $search_term); //remove any question marks from string
$search_count = str_word_count($search_term); //count words of string entered by user
$array = explode(" ", $search_term); //Seperate user enterd data
foreach ($array as $key=>$word) {
$array[$key] = " title LIKE '%".$word."%' "; //creates condition for MySQL query
}
$q = "SELECT * FROM posts WHERE " . implode(' OR ', $array); //Query to select data with word matches
$r = mysql_query($q);
$count = 0; //counter to limit results shown
while($row = mysql_fetch_assoc($r)){
$thetitle = $row['title']; //result from query
$thetitle = str_replace ("?", "", $thetitle); //remove any question marks from string
$title_array[] = $thetitle; //creating array for query results
$newarray = explode(" ", $search_term); //Seperate user enterd data again
foreach($title_array as $key => $value) {
$thenewarray = explode(" ", $value); //Seperate each result from query
$wordmatch = array_diff_key($thenewarray, array_flip($newarray));
$result = array_intersect($newarray, $wordmatch);
$matchingwords = count($result); //Count the number of matching words from
//user entered data and the database query
}
if(mysql_num_rows($r)==0)//no result found
{
echo "<div id='search-status'>No result found!</div>";
}
else //result found
{
echo "<ul>";
$title = $row['title'];
$percentage = '.5'; //percentage to take of search word count
$percent = $search_count - ($search_count * $percentage); //take percentage off word count
if ($matchingwords >= $percent){
?>
<li><a href='<?php echo $row['url']; ?>'><?php echo $title ?><i> No. matching words: <?php echo $matchingwords; ?></i></a></li>
<?php
$count++;
if ($count == 5) {break;
}
}else{
}
}
echo "</ul>";
}
?>
下の画像は、検索バーで「自分のウェブサイトを作成する方法」を検索するとどうなるかを示しています。テスト用のデータベースにはすでにいくつかの質問があり、それらはすべて同様の質問であり、最後のエントリの 1 つは私が尋ねた質問と完全に一致していますが、現在それらを最初の 5 つの数学結果として表示しているため、完全な一致は無視されます。その検索結果がこちら。
各質問に一致する単語がいくつあるかを示すコードを少し追加しました。また、データベース内の最初の 5 件の一致結果が昇順で表示されているのも偶然です。
データベース全体から最も近い一致を最初に表示し、次に 2 番目に最適な一致、3 番目などを表示するように配置するには、これにどのコードを追加する必要がありますか?