-1

私の検索機能

     <?php
    $i=0;
    $column_name = 'title'; // column to search by
    $k =$_GET['k'];
    $terms = explode(" ",$k);
    //connect before calling mysql_real_escape_string
    mysql_connect("localhost","","");
    mysql_select_db("test");
    $query ="SELECT bookid,title,author 
    FROM  books WHERE";
    foreach ($terms as $each){
        $i++;
        $each = '%' . $each . '%'; // add wildcard
        $each = mysql_real_escape_string($each); // prevent sql injection
        if($i==1)
            $query .= " $column_name LIKE '$each' ";
        else
            $query .= " OR $column_name LIKE '$each' ";

    }

    echo 'QUERY: ' . $query;

    $query = mysql_query($query) OR DIE(mysql_error());

//Code below is for using the relationships table assuming you have a column name id that
//references to the relationships table. Also, you should add a index on the column id.

$results = "";

while($row = mysql_fetch_array($query)) {
  $results .= '<li>
                <a href="book-relationships.php?id='.$row['id'].'">'.$row['title'].'  author: '.$row['author'].'</a>
              </li>';
}

$results = '<ul>' . $results . '</ul>';

echo $results;

検索時にあるデータベースを別のデータベースにリンクするのに助けが必要です.このデータベースは検索で出てきたすべての本をリストし、それらを関係と呼ばれる別のテーブルと比較し、検索された本と関係のある本のタイトルを出力します.

検索が実行されると、これがブラウザで生成されます

QUERY: SELECT id,title,author FROM books WHERE title LIKE '%jarrads%' Unknown column 'id' in 'field list'

私は100%立ち往生しています

スキーマ

本 - bookid、タイトル、著者、出版年、出版社.....

bookOne と bookTwo、bookid に関連

4

1 に答える 1

0

エラーメッセージが示すように、クエリにエラーがあります:

Unknown column 'id' in 'field list'

books有効なフィールドのリストについては、テーブルを確認してください。これを実現する 1 つの方法は、次のクエリを実行することです。

SHOW CREATE TABLE books;

于 2012-05-21T15:50:19.447 に答える