[英]multiple search queries in mysql?
我有一个简单的搜索查询脚本,当用户输入关键字时,它会在数据库中调出与那些查询匹配的任何用户。
目前,一个用户一次只能搜索一个查询,但我想知道如何修改此脚本,以便一个用户可以搜索多个查询,因此,如果他们输入白人英国男性,则所有用户都将列为白人,英国人和男性。 或者,如果他们搜索威尔士40岁以上的女性,那么就会获得所有威尔士40岁以上女性的用户。
$query_for_result=mysql_query("SELECT *
FROM ptb_stats
WHERE display_name like '%".$query."%' OR and location LIKE '%".$query."%' OR age LIKE '%".$query."%' OR nationality LIKE '%".$query."%' OR hobbies LIKE '%".$query."%' OR ethnicity LIKE '%".$query."%' OR local_station LIKE '%".$query."%' LIMIT 5");
echo "<div class=\"search-results\">";
while($data_fetch=mysql_fetch_array($query_for_result))
{
你有一个额外的and
比你的SQL看起来很好在那里,等。 虽然我确实希望您正在清理$query
。
您可能要考虑要使用OR
还是AND
这取决于您要对搜索执行的操作。 几乎可以肯定,您还希望构建SQL字符串以仅包含要搜索的列。 例如:
if( isset($query_age) ) {
$sql_string .= " OR age LIKE '%".$query_age."%'";
}
etc...
您可以实现对PHP页面的客户端Ajax调用,这将依次进行数据库查询并向客户端返回XML或JSON答案。 然后,您在本地更新客户端。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.