问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

怎么用php实现站内搜索功能

发布网友 发布时间:2022-04-26 17:18

我来回答

2个回答

懂视网 时间:2022-04-06 05:48

php实现站内搜索的方法:1、利用SQL的LIKE来实现站内搜索;2、利用谷歌搜索引擎API以及谷歌搜索功能,建立站内搜索;3、通过“PHP+MYSQL+SCWS”做站内搜索引擎。

推荐:《PHP视频教程》

PHP+MYSQL+SCWS 做自己的站内搜索引擎

天底下竟然有这么一种站内搜索引擎,它支持中文分词,支持全文搜索,无须任何扩展,不用对服务器进行任何设置,只要支持PHP和MYSQL就行,他操作简单,效率高,效果好.这就是PHP+MYSQL+SCWS 站内搜索引擎.

事实上,无论大小,从新浪到爱卡汽车网,从日PV过亿的网站到我自己的个人博客,都需要站内搜索引擎.站内搜索引擎对于网站的作用,是不言而喻的.最直接的作用是让用户以最直接的方式,最快的速度在你的网站里找到他想要的东西.而不是再到百度谷歌去,搜索到别人的网站.

(一) 最基本的站内搜素利用SQL的LIKE

例如

SELECT * FROM bbs_threads WHERE subject LIKE '%搜索引擎%' LIMIT 10

优点:太容易了,是人都会

缺点: 1. 每次执行LIKE语句都需要一次表遍历,用的是字符串比较,效率太低. 2. 不能分词,只能整句话搜索.如果搜索词较长,几乎搜索不出任何结果.如果加上分词功能,相当于一条语句里使用好几个LIKE,同1.

(二) 谷歌自定义搜索

利用谷歌搜索引擎API以及谷歌强大的搜索功能,建立自己的站内搜索. 演示: http://www.lusongsong.com/search.html?cx=014724041144905348996:pf5fnahnzuw&cof=FORID:11&ie=UTF-8&q=危机&sa=搜索&siteurl=lusongsong.com/

优点: 省心,没有比这个再省心的了.你啥都不用管.谷歌都是自家的了,人家的搜索算法,那怎么是咱们能比得了的呢.

缺点: 1.需要使用IFRAME,或者直接打开谷歌的页面,或者用更复杂的API来实现. 2.只能按照文本搜索,只能全站搜索.我要想在某个频道下,搜索指定类型的文章等要求谷歌就不能实现了.一句话,就是不能自定义. 3.如果你的网站小,谷歌人家都不带收录你,啥也搜不出来你咋办?

(三) lucene 全世界最好的开放源代码搜索引擎

呃…没啥好介绍的,直接看优缺点吧

优点: 完全开放源代码,完全可以自定义,完全…..

缺点: java写的,哥不会.你会java?你改个试试

(四) PHP+MYSQL+SCWS 做自己的站内搜索引擎

千呼万唤始出来!

MySQL支持全文索引和搜索。全文索引在 MySQL 中是一个 FULLTEXT 类型索引。FULLTEXT 索引用于 MyISAM 表,可以在 CREATE TABLE 时或之后使用 ALTER TABLE 或 CREATE INDEX 在 CHAR、VARCHAR 或 TEXT 列上创建。

函数 MATCH() 对照一个文本集(包含在一个 FULLTEXT 索引中的一个或多个列的列集)执行一个自然语言搜索一个字符串。搜索字符串做为 AGAINST() 的参数被给定。搜索以忽略字母大小写的方式执行。对于表中的每个记录行,MATCH() 返回一个相关性值。即,在搜索字符串与记录行在 MATCH() 列表中指定的列的文本之间的相似性尺度。

当 MATCH() 被使用在一个 WHERE 子句中时,返回的记录行被自动地以相关性从高到低的次序排序。相关性值是非负的浮点数字。零相关性意味着不相似。

在英语环境下,使用PHP和MYSQL就完全能够建立全文检索环境.步骤为:

1. 建立内容表,灌入数据,在需要全文检索的字段上建立FULLTEXT索引

2. 利用MATCH函数执行搜索条件

3. 处理返回的数据,显示结果

简单吧。。。

问题是,中文不是自分词的语言,在MYSQL开来一大段中文就是一个单词,全文检索就失效了.解决这个问题的办法是,在灌入数据和搜索前,利用其他的工具来进行分词,将大段的中文分隔为一个一个的词,类似与英文的单词.

最简单的工具就是SCWS. 官方站点: http://www.ftphp.com/scws/

SCWS 是 Simple Chinese Words Segmentation 的缩写,即简易中文分词系统。

这是一套基于词频词典的机械中文分词引擎,它能将一整段的汉字基本正确的切分成词。词是汉语的基本语素单位,而书写的时候不像英语会在词之间用空格分开,所以如何准确而又快速的分词一直是中文分词的攻关难点。

SCWS 在概念上并无创新成分,采用的是自行采集的词频词典,并辅以一定程度上的专有名称、人名、地名、数字年代等规则集,经小范围测试大概准确率在 90% ~ 95% 之间,已能基本满足一些中小型搜索引擎、关键字提取等场合运用。 SCWS 采用纯 C 代码开发,以 Unix-Like OS 为主要平台环境,提供共享函数库,方便植入各种现有软件系统。此外它支持 GBK,UTF-8,BIG5 等汉字编码,切词效率高。

SCWS提供了纯PHP代码编写的中文分词类,使它不需要做任何额外的扩展就能在机会所有的服务器上使用.

支持中文的基于PHP+MYSQL的全文检索的步骤为:

1. 建立内容表(,将数据分词),灌入数据,在需要全文检索的字段上建立FULLTEXT索引

2. (将要搜索的内容先分词再) 利用MATCH函数执行搜索条件

3. 处理返回的数据,显示结果

仍然是SO EASY!

一个演示的例子: http://www.bnet.com.cn/files/search.php?word=%CA%D5%B9%BA&page=3

执行搜索的语句是:

SELECT SQL_CALC_FOUND_ROWS *, MATCH (titlewords, keywords, author, contentwords) AGAINST ('$words') AS matchscore
FROM search
WHERE MATCH (titlewords, keywords, author, contentwords) AGAINST ('$words') > 0.5

热心网友 时间:2022-04-06 02:56

所谓站内搜索就是搜索数据库内容,重点是sql语句,并不是PHP
搜索时候对数据库一张或多张表进行查询得出结果,对结果进行处理使其成为一条条消息,然后每条消息中添加链接(一般来说 这个链接地址会和数据库 表名 以及 数据库内容的主键有关联)
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
为什么来大姨妈胸会胀 少儿学什么舞蹈 青年学什么舞蹈好 成年人学什么舞蹈 福州企业最低工资标准 2013年厦门的底薪是多少 生产要素的需求有哪些性质 生产要素的需求有何特点? 什么是生产要素需求 微观经济学要素需求什么是条件要素需求?它和要素需求有什么不同?_百度... php怎么实现根据图片搜索图片功能 当兵新兵连累吗, 怎么在网页上用PHP做个搜索功能? 当兵是不是很累啊? php 如何实现文章内容搜索? 我想知道当兵的人在部队生活是不是很累… EXCEL文档中打入的文字如何全部显示 php如何实现下拉框选中搜索功能 PHP中怎么实现关键字搜索? 当兵累吗?我想去 PHP搜索怎么做 现在当兵累不累 荣耀60支持北斗吗? 当兵有多苦有多累? 公积金贷款收入证明要银行流水吗 当兵辛苦吗? 公积金贷款查流水严吗 武汉公积金贷款需要的流水 20元购买下载了的北斗导航,导航一会儿就息屏了感觉特不方便,寻求解决办法!我是华为P30pol 申请公积金贷款需要提供银行流水吗 php要实现简单的查找功能,只要一个输入查找内容的编辑框并且要和查找... 当兵到底累不累啊? 如何用PHP制作搜索引擎 php程序中的搜索功能 关于php 站内搜索 的实现~~ thinkphp 怎么在模板页面做一个搜索功能 如何用php实现动态搜索功能,希望大神指点一下思路。 如何用PHP和ajax实现实时搜索功能 PHP如何实现模糊搜索? PHP技术 如何实现网站内高效搜索? 想用php做一个搜索功能,不知道错在哪里,各位大侠们帮帮忙 phpcms里如何实现多功能搜索 酷我音乐的微信先享卡什么 PHP 怎样实现随便输入一个字都能搜索全数据库的内容? 我新办了微信先享卡,月费折扣是立即生效的吗? 微信先享卡不交钱会怎样? 微花先享后付怎么取消 有人知道微信先享卡吗? 微花的先享后付魅力那么大吗?为什么身边好多人都在用微花,不怕是套路贷嘛 酷我音乐微信先享卡首月付费不能付费是为什么?