http://www.cnblogs.com/imbin/archive/2011/09/13/2174943.html 目前正在用phpcms v9,需要显示热门搜索关键词,Google了几下没找到完善的解决办法。 还是DIY吧。 通过观察可以发现系统是自带了关键词模型的,只是没有实现。 或许是放在下一个版本里,呵呵~ DIY就从 /phpcms/model/keyword_model.class.php入手了。 看一下keyword_model.class.php的内容 defined('IN_PHPCMS') or exit('No permission resources.'); pc_base::load_sys_class('model', '', 0); class keyword_model extends model { public $table_name = ''; public function __construct() { $this->db_config = pc_base::load_config('database'); $this->db_setting = 'default'; $this->table_name = 'keyword'; parent::__construct(); } } 从代码可以看出关键词表名叫 keyword 可是我们查看数据库里没有这样的表名。 那就参照相关搜索数据表 tb_search_keyword(我安装的时候用的是tb做表前缀) 新建一个热门搜索关键词数据表 keyword SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for `tb_keyword` -- ---------------------------- DROP TABLE IF EXISTS `tb_keyword`; CREATE TABLE `tb_keyword` ( `keyword` char(20) NOT NULL, `typeid` tinyint(4) NOT NULL default '0', `searchnums` int(10) unsigned NOT NULL default '0', PRIMARY KEY (`keyword`), UNIQUE KEY `keyword` (`keyword`) ) ENGINE=MyISAM DEFAULT CHARSET=gbk; 这样数据表就建好了,接下来就是添加和调用数据了。 打开文件 /phpcms/models/search/index.php 找到 //如果开启相关搜索功能 if($setting['relationenble']) { 在它上面加入以下代码 //加入搜索关键词记录 imbin 2011/9/13 if(!empty($result)){ $this->keyword_log_db = pc_base::load_model('keyword_model'); $res = $this->keyword_log_db->get_one(array('keyword'=>$q,'typeid'=>$typeid)); if($res) { //关键词搜索数+1 $this->keyword_log_db->update(array('searchnums'=>'+=1'), array('keyword'=>$q)); } else { $this->keyword_log_db->insert(array('keyword'=>$q,'typeid'=>$typeid, 'searchnums'=>1)); } } 这样就实现了搜索关键词的添加 再来看看模板调用的实现,我用的是 get 标签。 首先看搜索结果页:/phpcms/templates/default/search/list.html {pc:get sql="SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid AND searchnums > 5 ORDER BY rand()" num="5" return="keywords"} {loop $keywords $k=>$v}{$v['keyword']}{/loop} {/pc} 这里的排序我用了随机,因为我不想每次都出现一样的,呵呵。 附上按搜索次数排序的Sql语句:SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid ORDER BY searchnums DESC 如果是在首页调用,需要去掉$typeid。BTW:如果要在非搜索结果页都要去掉$typeid {pc:get sql="SELECT keyword,typeid FROM tb_keyword ORDER BY searchnums DESC" num="8" return="keywords"} {loop $keywords $k=>$v}{$v['keyword']}{/loop} {/pc} OK了,DIY完成!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述