【phpcms-v9】为phpcms-v9添加热门搜索关键词
发布:smiling 来源: PHP粉丝网 添加日期:2014-10-24 09:44:23 浏览: 评论:0
目前正在用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`), --phpfensi.com
- UNIQUE KEY `keyword` (`keyword`)
- ) ENGINE=MyISAM DEFAULT CHARSET=gbk;
这样数据表就建好了,接下来就是添加和调用数据了,打开文件 /phpcms/models/search/index.php.
找到:
- //如果开启相关搜索功能
- if($setting['relationenble']) {
- //在它上面加入以下代码
- //加入搜索关键词记录 imbin 2011/9/13
- if(!emptyempty($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}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}a>{/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}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}a>{/loop}
- {/pc}
OK了,DIY完成.
Tags: phpcms关键词 phpcms热门搜索
相关文章
- ·说一说PHPCMS V9中自动生成关键词的segment类和dict的关键词库(2014-10-22)
- ·phpcms v9增加类似于phpcms 2008中的关键词表(2015-02-16)
- ·phpcms v9添加热门搜索关键词(2015-03-24)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)