- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 jQuery 创建了一个 DropDown 自动完成菜单。主要思想是,一旦将键插入文本框(最少 3 个字符),该函数就会使用 GET 方法向不同的页面(比如:search.php?q=iron man 3)和页面(search.php)发送请求。 php) 使用 MySQL 和 PHP 5 创建结果并显示它们。
到这里似乎没问题,但由于我的网站上有很多用户(每天大约 10,000 名用户),每次他们按下一个键都需要查询,这会在服务器上造成大量过载。这会减慢服务器速度。
是否有更智能的方法来制作下拉自动完成菜单?
谢谢。
最佳答案
我假设您已经规范化并简化了您正在查询的表。最好只查询一个表,该表有一个名称字段,一些分数(例如流行度)用于排名结果(如果适用),可能是一个 movie_id 将您链接到实际电影数据或您正在查询的任何内容,也许还有一个数据类型( Actor 、电影等)的标识符。
您不必对所有内容进行规范化,只需将此数据移动到单独的表中,然后在每次您想查看名称时运行连接。这可能只是数据的额外副本。您甚至可以使用您通常不会使用的存储引擎,例如内存或 MyISAM(请参阅下面的文本搜索)来提高性能。
添加是在运行查询时添加一些条件。在他们停止输入一小段时间(0.5+ 秒左右,默认为 0.3 秒)之前不要运行查询。这将是提高服务器稳定性的最简单和最快捷的方法,但会以响应速度为代价,因为它们必须停止更长时间。您也可以尝试避免客户端运行多个同时查询,这对读者来说是一个练习,但如果有适当的延迟,这可能是无用的。如果您从 Google 来到这里,您可以在 http://docs.jquery.com/UI/API/1.8/Autocomplete 查看相应的 jquery 自动完成文档。 .
$( ".selector" ).autocomplete({
minLength: 3, // already set
delay: 500
});
另一个改进是使用文本搜索引擎。 MySQL 使用 MyISAM 和 InnoDB(5.6 中的新功能)引擎进行了一些全文搜索,但 MyISAM 有一些折衷,InnoDB 全文可能无法提供生产就绪的结果(as shown here)。幸运的是,在 MySQL 中切换表类型相当容易,并且拥有一个只有名称副本的小表应该可以缓解任何问题。对于更复杂的 DBA 操作,一些数据库让您自己重建所有内容。
如果您的站点变得足够繁忙,专用搜索引擎可能是个好主意,例如 Lucene/CLucene (一个 C++ 端口),Solr (Lucene 子项目),Sphinx或 Xapian仅举几例。
关于我看到的唯一真正的替代方法是将整个数据集推送给每个访问者,并让客户端在 javascript 中自行处理查询和结果。对于 HTML5 应用程序,这可能有一些用处,但要确保数据被缓存。
关于php - jQuery 自动完成菜单正在阻塞服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16402437/
从 Redis 获取消息时,onDone:(){print('done')} 从未起作用。 import 'package:dartis/dartis.dart' as redis show PubS
昨天我玩了一些vim脚本,并设法通过循环来对当前输入的内容进行状态栏预测(请参见屏幕截图(灰色+黄色栏))。 问题是,我不记得我是怎么得到的,也找不到我用于该vim魔术的代码片段(我记得它很简单):它
我尝试加载 bash_completion在我的 bash (3.2.25) 中,它不起作用。没有消息等。我在我的 .bashrc 中使用了以下内容 if [ -f ~/.bash_completio
我正在尝试构建一个 bash 完成例程,它将建议命令行标志和合适的标志值。例如在下面 fstcompose 命令我想比赛套路先建议 compose_filter= 标志,然后建议来自 [alt_seq
当我尝试在重定向符号后完成路径时,bash 完成的行为就好像它仍在尝试在重定向之前完成命令的参数一样。 例如: dpkg -l > /med标签 通过在 /med 之后点击 Tab我希望它完成通往 /
我的类中有几个 CAKeyframeAnimation 对象。 他们都以 self 为代表。 在我的animationDidStop函数中,我如何知道调用来自哪里? 是否有任何变量可以传递给 CAKe
我有一个带有 NSDateFormatter 的 NSTextField。格式化程序接受“mm/dd/yy”。 可以自动补全日期吗?因此,用户可以输入“mm”,格式化程序将完成当前月份和年份。 最佳答
有一个解决方案可以使用以下方法完成 NSTextField : - (NSArray *)control:(NSControl *)control textView:(NSTextView *)tex
我正在阅读 Passport 的文档,我注意到 serialize()和 deserialize() done()被调用而不被返回。 但是,当使用 passport.use() 设置新策略时在回调函数
在 ubuntu 11.10 上的 Firefox 8.0 中,尽管 img.complete 为 false,但仍会调用 onload 函数 draw。我设法用 setTimeout hack 解决
假设我有两个与两个并行执行的计算相对应的 future 。我如何等到第一个 future 准备好?理想情况下,我正在寻找类似于Python asyncio's wait且参数为return_when=
我正在寻找一种 Java 7 数据结构,其行为类似于 java.util.Queue,并且还具有“最终项目已被删除”的概念。 例如,应可以表达如下概念: while(!endingQueue.isFi
这是一个简单的问题。 if ($('.dataTablePageList')) { 我想做的是执行一个 if 语句,该语句表示如果具有 dataTablesPageList 类的对象也具有 menu
我用replaceWith批量替换了许多div中的html。替换后,我使用 jTruncate 来截断文本。然而它不起作用,因为在执行时,replaceWith 还没有完成。 我尝试了回调技巧 ( H
有没有办法调用 javascript 表单 submit() 函数或 JQuery $.submit() 函数并确保它完成提交过程?具体来说,在一个表单中,我试图在一个 IFrame 中提交一个表单。
我有以下方法: function animatePortfolio(fadeElement) { fadeElement.children('article').each(function(i
我刚刚开始使用 AndEngine, 我正在像这样移动 Sprite : if(pValueY < 0 && !jumping) { jumping =
我正在使用 asynctask 来执行冗长的操作,例如数据库读取。我想开始一个新 Activity 并在所有异步任务完成后呈现其内容。实现这一目标的最佳方法是什么? 我知道 onPostExecute
我有一个脚本需要命令名称和该命令的参数作为参数。 所以我想编写一个完成函数来完成命令的名称并完成该命令的参数。 所以我可以这样完成命令的名称 if [[ "$COMP_CWORD" == 1 ]];
我的应用程序有一个相当奇怪的行为。我在 BOOT_COMPLETE 之后启动我的应用程序,因此在我启动设备后它是可见的。 GUI 响应迅速,一切正常,直到我调用 finish(),按下按钮时,什么都没
我是一名优秀的程序员,十分优秀!