我有一个包含 100-200k 记录的数据库表,我需要对其进行优化。例如,如果用户想要搜索词car,他将获得大约 25k 条结果。
我想为他提供 500 条最新结果,但该怎么做?我知道我必须使用LIMIT
,但我不确定如何将最新的 500 行“分组”。
为了更好地了解我现在如何从数据库中获取数据,这里有一个小片段:
$search = mysql_real_escape_string(searched_query($_GET['skill']));
$q = "...long sql query...";
echo $q;
$result = mysql_query($q);
$items = 30; // number of items per page.
$all = $_GET['a'];
$num_rows = mysql_num_rows($result);
if($all == "all"){
$items = $num_rows;
}
$nrpage_amount = $num_rows/$items;
$page_amount = ceil($num_rows/$items);
$page_amount = $page_amount-1;
$page = mysql_real_escape_string($_GET['p']);
if($page < "1"){
$page = "0";
}
$p_num = $items*$page;
// Query that you would like to SHOW
$result = mysql_query($q." ORDER BY published DESC LIMIT $p_num , $items");
先感谢您!