当前位置: 首页 > 面试题库 >

MySQL / PHP搜索效率

姚嘉容
2023-03-14
问题内容

我正在尝试为我的网站创建一个小型搜索。我曾尝试使用全文本索引搜索,但无法使用它。这是我想出的:

if(isset($_GET['search'])) {

$search = str_replace('-', ' ', $_GET['search']);
$result = array();

$titles = mysql_query("SELECT title FROM Entries WHERE title LIKE '%$search%'");
while($row = mysql_fetch_assoc($titles)) {
    $result[] = $row['title'];
}

$tags = mysql_query("SELECT title FROM Entries WHERE tags LIKE '%$search%'");
while($row = mysql_fetch_assoc($tags)) {
    $result[] = $row['title'];
}

$text = mysql_query("SELECT title FROM Entries WHERE entry LIKE '%$search%'");
while($row = mysql_fetch_assoc($text)) {
    $result[] = $row['title'];
}

$result = array_unique($result);
}

因此,基本上,它搜索数据库中所有条目的所有标题,正文和标记。这工作得很好,但是我只是想知道它的效率如何?这也只适用于小型博客。无论哪种方式,我都只是想知道是否可以提高效率。


问题答案:

无法提高LIKE '%pattern%'查询效率。一旦获得大量数据,使用通配符查询将比使用全文本索引解决方案慢数百倍或数千倍。

您应该看一下我为MySQL大学所做的演示:http : //www.slideshare.net/billkarwin/practical-
full-text-search-with-my-sql

这是使其工作的方法

  1. 首先确保您的表使用MyISAM存储引擎。MySQL FULLTEXT索引仅支持MyISAM表。( 2012年11月1日编辑: MySQL 5.6为InnoDB表引入了FULLTEXT索引类型。)

    ALTER TABLE Entries ENGINE=MyISAM;
    
  2. 创建全文索引。

    CREATE FULLTEXT INDEX searchindex ON Entries(title, tags, entry);
    
  3. 搜索一下!

    $search = mysql_real_escape_string($search);
    

    $titles = mysql_query(“SELECT title FROM Entries
    WHERE MATCH(title, tags, entry) AGAINST(‘$search’)”);
    while($row = mysql_fetch_assoc($titles)) {
    $result[] = $row[‘title’];
    }

请注意,在MATCH子句中命名的列 必须 与在全文索引定义中声明的列相同,并且顺序相同。否则它将无法正常工作。

我曾尝试使用全文本索引搜索,但我无法使其正常工作……我只是想知道这样做是否可以提高效率。

这就像在说:“我不知道该如何使用电锯,所以我决定用小刀砍掉这棵红木树。我如何使它和电锯一样好?”

关于您关于搜索匹配超过50%行的单词的评论。

MySQL手册说这个:

需要绕过50%限制的用户可以使用布尔搜索模式;请参见第11.8.2节“布尔全文搜索”。

与此:

自然语言搜索的50%阈值由所选的特定加权方案确定。要禁用它,请在storage / myisam / ftdefs.h中查找以下行:

将该行更改为此:

define GWS_IN_USE GWS_FREQ

然后重新编译MySQL。在这种情况下,无需重建索引。

另外,您可能正在搜索 停用词 。这些是全文搜索会忽略的单词,因为它们太常见了。诸如“
the”之类的词。见http://dev.mysql.com/doc/refman/5.1/en/fulltext-
stopwords.html



 类似资料:
  • 问题内容: 我正在努力创建一个搜索多个单词的搜索。我的第一次尝试没有任何结果,结果如下: 我还尝试了以下方法,这些方法产生了结果,但是正如您可以想象的那样,我输入的每个单词都得到了重复的结果: 我对如何进行此操作非常迷惑,不胜感激。 编辑: 问题答案: 我已经在同一个主题(搜索关键字)上工作了一段时间,这是我的工作方式: -现在这就是我尝试使用FULLTEXT搜索运行它的样子:但是您应该将表类型设

  • 问题内容: 我只是在寻找有关最佳方法的建议… 我需要创建一个搜索功能,以在邮政编码的50英里半径内搜索“用户”。我有一个邮政编码表,其中包含所有美国邮政编码及其纬度/经度,但我只是想找出构造和查询数据的最佳方式… 是否应在用户表中添加纬度/经度列,并在给定邮政编码范围内的所有用户查询它?还是应该在邮政编码表中查询半径范围内的所有邮政编码,然后在用户表中查询所有具有结果(邮政编码)的用户?要么… ?

  • 问题内容: 我知道如何进行常规的php mysql搜索并显示结果。但是,由于我要完成的工作的性质,我需要能够按相关性进行排序。让我更好地解释一下: 普通查询“ apple iphone应用程序”将使用%apple iphone application%搜索数据库,但是如果没有记录以该确切顺序显示该短语,则搜索将不会产生任何结果。 我基本上需要做的是分别搜索“ apple”,“ iphone”和“

  • 问题内容: 如何突出显示使用php的mysql查询的搜索结果? 这是我的 [修改] 代码: 问题答案: 您可以使用preg_replace();,当它在文本中找到匹配项时,您可以在匹配词周围放置一个带有突出显示类别的div。然后,您可以向突出显示类添加背景颜色和边框,以使其突出显示 preg_replace期望3个参数; 第一个是您要寻找的 第二个是应该更改为 他应从中搜索并替换的文本字符串 例如

  • 问题内容: 我的数据库中有三个表: 这些表中的每个表都有两个字段,分别称为“内容”和“标题”。我希望能够在我的sql语句中使用“赞”来查看“ messages.content”,“ messages.title”,“ topics.content”,“ topics.title”,“ comments.content”和“ comments”。标题”使用关键字。 到目前为止,我的查询仅能从一张表中

  • 问题内容: 我有一个MySQL表(MyISAM),其中包含我根据与另一对经纬度对之间的距离(大圆公式)从中选择的约20万经纬度对条目。(例如,在50.281852,2.504883附近的10公里半径内的所有条目) 我的问题是此查询大约需要0.28秒。仅针对这200k条目运行(每天仍在增加)。而0.28秒。通常情况下会很好,此查询会经常运行,因为它会增强我的Web应用程序的主要功能,而且通常是较大查