高级自动完成列表

时间:2012-11-26 15:24:17

标签: php jquery mysql

我创建了这个查询,用jQuery显示我的自动完成框。它工作得很好。

<?php

require_once('database.php');

if(isset($_POST['queryString'])) {

    $queryString = $dbc->real_escape_string($_POST['queryString']);

    if(strlen($queryString) >0) {
        $q = "SELECT keyword 
                FROM (
                    SELECT tname AS keyword FROM t
                    UNION
                    SELECT sname AS keyword FROM sub
                    UNION
                    SELECT cname AS keyword FROM c
                    UNION
                    SELECT iname AS keyword FROM i
                ) s
              WHERE keyword LIKE '%$queryString%' 
              LIMIT 10";

        $r = mysqli_query ( $dbc, $q);

        if($q) {
            while ($row = mysqli_fetch_array($r, MYSQL_ASSOC)) {
                echo '<li onClick="fill(\''.$row['keyword'].'\');">'.$row['keyword'].'</li>';
            }
        } else {
            echo 'ERROR: There was a problem with the query.';
        }
    } else {

    }
} else {
    echo 'There should be no direct access to this script!';
}

?> 

使用此查询显示自动完成列表,其中包含主题,教师姓名,城市根据关键字。现在我需要修改具有更多值的自动完成列表。例如,列表中有一个导师姓名,我想显示他/她当前的城市,他/她的个人资料图片等。这与Facebook搜索类似。

这是我的城市和地址表

# --------------
# Address Table
# --------------

CREATE TABLE address (
address_id INT(4) UNSIGNED NOT NULL AUTO_INCREMENT,
address_one VARCHAR(40) NOT NULL, 
address_two VARCHAR(40) DEFAULT NULL, 
city_id INT(4) UNSIGNED NOT NULL,
PRIMARY KEY (address_id),
) ENGINE=MyISAM DEFAULT CHARSET=utf8;


# --------------
# City Table
# --------------

CREATE TABLE city(
city_id INT(4) UNSIGNED NOT NULL AUTO_INCREMENT,
city_name VARCHAR(30) NOT NULL, 
district_id INT(2) UNSIGNED NOT NULL,
PRIMARY KEY (city_id),
UNIQUE (city_name)
) ENGINE=MyISAM;

我该怎么做?

1 个答案:

答案 0 :(得分:0)

我认为有两种选择。

我相信你应该调整你的查询,因为现在你查看t表和子表中检查是否出现了搜索词。但是,您的查询太短,以至于您没有可用的匹配配置文件信息,只有您执行搜索的列。

当然,你不想从甚至不符合你标准的行查询大量数据。另一方面,执行搜索后执行大量查询并不方便。但是,由于您的限制为10,所以应该没问题。

将您的查询更改为select name, birthday, gender, imgdata from t等..