我创建了这个查询,用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;
我该怎么做?
答案 0 :(得分:0)
我认为有两种选择。
我相信你应该调整你的查询,因为现在你查看t表和子表中检查是否出现了搜索词。但是,您的查询太短,以至于您没有可用的匹配配置文件信息,只有您执行搜索的列。
当然,你不想从甚至不符合你标准的行查询大量数据。另一方面,执行搜索后执行大量查询并不方便。但是,由于您的限制为10,所以应该没问题。
将您的查询更改为select name, birthday, gender, imgdata from t
等..