如何将typeahead.js与大型数据库一起使用

时间:2013-08-06 15:29:41

标签: javascript ajax database typeahead.js

我有一个包含10,000个地址和5,000人的大型数据库。

我想让用户在数据库中搜索地址或用户。我想使用Twitter的预先输入文字来建议结果。

请在此处查看NBA示例:http://twitter.github.io/typeahead.js/examples

据我所知,从速度和负载的角度来看,预取15,000个项目并不是最佳选择。什么是尝试实现这一目标的更好方法?

1 个答案:

答案 0 :(得分:46)

由于没有人做出任何回答,我会继续提出我的建议。

我认为最适合您的大数据库的是使用remotetypeahead.js。快速举例:

$('#user-search').typeahead({
    name: 'user-search',
    remote: '/search.php?query=%QUERY' // you can change anything but %QUERY
});

它的作用是当你在input#user-search中输入字符时,它会向页面search.php发送AJAX请求,并将查询作为输入的内容。

search.php上,您可以捕获此查询并在数据库中查找:

$query = $_GET['query'].'%'; // add % for LIKE query later

// do query
$stmt = $dbh->prepare('SELECT username FROM users WHERE username LIKE = :query');
$stmt->bindParam(':query', $query, PDO::PARAM_STR);
$stmt->execute();

// populate results
$results = array();
foreach ($stmt->fetchAll(PDO::FETCH_COLUMN) as $row) {
    $results[] = $row;
}

// and return to typeahead
return json_encode($results);

当然,由于您的数据库非常大,您应该优化SQL查询以更快地查询,也可以缓存结果等。

在预先输入方面,为了减少查询数据库的负担,您可以指定minLengthlimit

$('#user-search').typeahead({
    name: 'user-search',
    remote: '/search.php?query=%QUERY',
    minLength: 3, // send AJAX request only after user type in at least 3 characters
    limit: 10 // limit to show only 10 results
});

因此,您的数据库的大小并不重要,这种方法应该可以很好地工作。

这是PHP中的一个示例,但当然对于您拥有的后端应该是相同的。希望你能得到基本的想法。