v9添加热门搜索关键词的方法-phpcms

技术教程 2026-01-09 15:29:46 浏览

通过观察可以发现系统是自带了关键词模型的,只是没有实现 或许是放在下一个版本里,呵呵~ DIY就从 /phpcms/model/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;

这样数据表就建好了,接下来就是添加和调用数据了。

复制代码

代码如下:

//如果开启相关搜索功能if($setting['relationenble']) {

在它上面加入以下代码

v9添加热门关键词的方法

复制代码

代码如下:

//加入搜索关键词记录 imbin 2011/9/13if(!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 标签。

复制代码

代码如下:

{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}

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐