【phpcms-v9】为phpcms-v9添加热门搜索关键词

目前正在用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}
< 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}
< href ="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}" > {$v['keyword']} a>{/loop}
                          {/pc}

 

OK了,DIY完成!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值