加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 如何在字符串中搜索数千个可能的关键字

发布时间:2020-12-13 22:41:32 所属栏目:PHP教程 来源:网络整理
导读:我有一个包含数千个(约10,000个)关键字的数据库.当用户在我的网站上发布博客时,我希望自动搜索文本中的关键字,并使用任何直接匹配标记帖子. 到目前为止,我能想到的只是拉出整个关键字列表,循环遍历它,并检查帖子中是否存在每个标签……这看起来非常低效(即10
我有一个包含数千个(约10,000个)关键字的数据库.当用户在我的网站上发布博客时,我希望自动搜索文本中的关键字,并使用任何直接匹配标记帖子.

到目前为止,我能想到的只是拉出整个关键字列表,循环遍历它,并检查帖子中是否存在每个标签……这看起来非常低效(即10000次循环).

有没有更常见的方法来做到这一点?我是否应该使用MySQL查询来限制它?

我想这不是一项非常罕见的任务.

不,只是不要这样做.

不是循环遍历10000个元素,最好从句子或文本中提取单词,然后将其添加到SQL查询中,这样就可以获得所有需要的记录.这肯定比您提出的解决方案更有效.

您可以使用PHP以下列方式执行此操作:

$possible_keywords = preg_split('/b/',$your_text,PREG_SPLIT_NO_EMPTY);

上面将分割单词’boundary’上的文本,并且不会返回数组中的空元素.

然后,您可以以类似于以下的方式创建SQL查询:

SELECT * FROM `keywords` WHERE `keywords`.`keyword` IN (...)

(只需将逗号分隔的提取单词列表放在括号中)

您应该在进行查询之前过滤$possible_keywords数组(仅包含具有适当长度的关键字并排除重复项)以及make关键字列索引.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读