国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > CMS > PhpCMS > 正文

phpcms v9添加熱門搜索關鍵詞

2024-09-10 07:16:20
字體:
來源:轉載
供稿:網友

通過觀察可以發現系統是自帶了關鍵詞模型的,只是沒有實現,或許是放在下一個版本里,呵呵~ DIY就從 /phpcms/model/keyword_model.class.php入手了.

看一下keyword_model.class.php的內容:

  1. defined('IN_PHPCMS'or exit('No permission resources.'); 
  2. pc_base::load_sys_class('model''', 0); 
  3. class keyword_model extends model { 
  4.     public $table_name = ''
  5.     public function __construct() { 
  6.         $this->db_config = pc_base::load_config('database'); 
  7.         $this->db_setting = 'default'
  8.         $this->table_name = 'keyword'
  9.         parent::__construct(); 
  10.     } 

從代碼可以看出關鍵詞表名叫 keyword 可是我們查看數據庫教程里沒有這樣的表名,那就參照相關搜索數據表 tb_search_keyword,我安裝的時候用的是tb做表前綴.

新建一個熱門搜索關鍵詞數據表 keyword:

  1. SET FOREIGN_KEY_CHECKS=0; 
  2.  
  3. -- ---------------------------- 
  4. -- Table structure for `tb_keyword` 
  5. -- ---------------------------- 
  6. DROP TABLE IF EXISTS `tb_keyword`; 
  7. CREATE TABLE `tb_keyword` ( 
  8.   `keyword` char(20) NOT NULL
  9.   `typeid` tinyint(4) NOT NULL default '0'
  10.   `searchnums` int(10) unsigned NOT NULL default '0'
  11.   PRIMARY KEY  (`keyword`), 
  12.   UNIQUE KEY `keyword` (`keyword`) 
  13. ) ENGINE=MyISAM DEFAULT CHARSET=gbk; 

這樣數據表就建好了,接下來就是添加和調用數據了,打開文件 /phpcms/models/search/index.php 找到如下代碼:

  1. //如果開啟相關搜索功能 
  2. if($setting['relationenble']) { 

在它上面加入以下代碼:

  1. //加入搜索關鍵詞記錄 imbin 2011/9/13 
  2.             if(!emptyempty($result)){ 
  3.                 $this->keyword_log_db = pc_base::load_model('keyword_model'); 
  4.  
  5.                     $res = $this->keyword_log_db->get_one(array('keyword'=>$q,'typeid'=>$typeid));  //開源軟件:Vevb.com 
  6.                     if($res) { 
  7.                         //關鍵詞搜索數+1 
  8.                         $this->keyword_log_db->update(array('searchnums'=>'+=1'), array('keyword'=>$q)); 
  9.                     } else { 
  10.                         $this->keyword_log_db->insert(array('keyword'=>$q,'typeid'=>$typeid'searchnums'=>1)); 
  11.                     } 
  12.             } 

這樣就實現了搜索關鍵詞的添加.

再來看看模板調用的實現,我用的是 get 標簽.

首先看搜索結果頁:/phpcms/templates/default/search/list.html

  1. {pc:get sql="SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid AND searchnums > 5 ORDER BY rand()" num="5" return="keywords"
  2.  {loop $keywords $k=>$v}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}</a>{/loop} 
  3. {/pc} 

這里的排序我用了隨機,因為我不想每次都出現一樣的,呵呵.

附上按搜索次數排序的Sql語句:SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid ORDER BY searchnums DESC

如果是在首頁調用,需要去掉$typeid,BTW:如果要在非搜索結果頁都要去掉$typeid

  1. {pc:get sql="SELECT keyword,typeid FROM tb_keyword ORDER BY searchnums DESC" num="8"  return="keywords"
  2. {loop $keywords $k=>$v}<a href="/index.php?typeid={$v['typeid']}&m=search&c=index&a=init&q={$v['keyword']}">{$v['keyword']}</a>{/loop} 
  3. {/pc}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昌都县| 巴林右旗| 康马县| 商水县| 浦东新区| 南平市| 靖宇县| 金山区| 承德市| 宣威市| 叙永县| 乐安县| 尉犁县| 会昌县| 松溪县| 扬中市| 长兴县| 阿瓦提县| 罗甸县| 合山市| 定南县| 昭通市| 南昌市| 阿合奇县| 巴青县| 平山县| 南通市| 镶黄旗| 佳木斯市| 上饶市| 吴江市| 淅川县| 松江区| 启东市| 安吉县| 香港| 郸城县| 陵水| 汤阴县| 萝北县| 根河市|