风趣的俊哥 發表於 2023-8-16 00:00:00

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

<p>
<span>通过观察可以发现系统是自带了关键词模型的,只是没有实现。 </span><br><span>或许是放在下一个版本里,呵呵~ DIY就从 /phpcms/model/keyword_model.class.php入手了。 </span><br><span>看一下keyword_model.class.php的内容 </span></p>
<div>
<p>
<span><u>复制代码</u></span></p>
<p>
代码如下:</p>
</div>
<p>
<br>
defined('IN_PHPCMS') or exit('No permission resources.'); <br>
pc_base::load_sys_class('model', '', 0); <br>
class keyword_model extends model { <br>
public $table_name = ''; <br>
public function __construct() { <br>
$this-&gt;db_config = pc_base::load_config('database'); <br>
$this-&gt;db_setting = 'default'; <br>
$this-&gt;table_name = 'keyword'; <br>
parent::__construct(); <br>
} <br>
} </p>
<p>
<br><span>从代码可以看出关键词表名叫 keyword 可是我们查看数据库里没有这样的表名。 </span><br><span>那就参照相关搜索数据表 tb_search_keyword(我安装的时候用的是tb做表前缀) </span><br><span>新建一个热门搜索关键词数据表 keyword </span></p>
<div>
<p>
<span><u>复制代码</u></span></p>
<p>
代码如下:</p>
</div>
<p>
<br>
SET FOREIGN_KEY_CHECKS=0; <br>
-- ---------------------------- <br>
-- Table structure for `tb_keyword` <br>
-- ---------------------------- <br>
DROP TABLE IF EXISTS `tb_keyword`; <br>
CREATE TABLE `tb_keyword` ( <br>
`keyword` char(20) NOT NULL, <br>
`typeid` tinyint(4) NOT NULL default '0', <br>
`searchnums` int(10) unsigned NOT NULL default '0', <br>
PRIMARY KEY (`keyword`), <br>
UNIQUE KEY `keyword` (`keyword`) <br>
) ENGINE=MyISAM DEFAULT CHARSET=gbk; </p>
<p>
<br><span>这样数据表就建好了,接下来就是添加和调用数据了。 </span><br><span>打开文件 /phpcms/models/search/index.php </span><br><span>找到 </span></p>
<div>
<p>
<span><u>复制代码</u></span></p>
<p>
代码如下:</p>
</div>
<p>
<br>
//如果开启相关搜索功能 <br>
if($setting['relationenble']) { </p>
<p>
<br><span>在它上面加入以下代码 </span></p>
<div>
<p>
<span><u>复制代码</u></span></p>
<p>
代码如下:</p>
</div>
<p>
<br>
//加入搜索关键词记录 imbin 2011/9/13 <br>
if(!empty($result)){ <br>
$this-&gt;keyword_log_db = pc_base::load_model('keyword_model'); <br>
$res = $this-&gt;keyword_log_db-&gt;get_one(array('keyword'=&gt;$q,'typeid'=&gt;$typeid)); <br>
if($res) { <br>
//关键词搜索数+1 <br>
$this-&gt;keyword_log_db-&gt;update(array('searchnums'=&gt;'+=1'), array('keyword'=&gt;$q)); <br>
} else { <br>
$this-&gt;keyword_log_db-&gt;insert(array('keyword'=&gt;$q,'typeid'=&gt;$typeid, 'searchnums'=&gt;1)); <br>
} <br>
} </p>
<p>
<br><span>这样就实现了搜索关键词的添加 </span><br><span>再来看看模板调用的实现,我用的是 get 标签。 </span><br><span>首先看搜索结果页:/phpcms/templates/default/search/list.html </span></p>
<div>
<p>
<span><u>复制代码</u></span></p>
<p>
代码如下:</p>
</div>
<p>
<br>
{pc:get sql="SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid AND searchnums &gt; 5 ORDER BY rand()" num="5" return="keywords"} <br>
{loop $keywords $k=&gt;$v}&lt;a href="/index.php?typeid={$v['typeid']}&amp;m=search&amp;c=index&amp;a=init&amp;q={$v['keyword']}"&gt;{$v['keyword']}&lt;/a&gt;{/loop} <br>
{/pc} </p>
<p>
<br><span>这里的排序我用了随机,因为我不想每次都出现一样的,呵呵。 </span><br><span>附上按搜索次数排序的Sql语句:SELECT keyword,typeid FROM tb_keyword WHERE typeid=$typeid ORDER BY searchnums DESC </span><br><span>如果是在首页调用,需要去掉$typeid。BTW:如果要在非搜索结果页都要去掉$typeid </span></p>
<div>
<p>
<span><u>复制代码</u></span></p>
<p>
代码如下:</p>
</div>
<p>
<br>
{pc:get sql="SELECT keyword,typeid FROM tb_keyword ORDER BY searchnums DESC" num="8" return="keywords"} <br>
{loop $keywords $k=&gt;$v}&lt;a href="/index.php?typeid={$v['typeid']}&amp;m=search&amp;c=index&amp;a=init&amp;q={$v['keyword']}"&gt;{$v['keyword']}&lt;/a&gt;{/loop} <br>
{/pc} </p>
<p>
<br><span>OK了,DIY完成!</span></p>
頁: [1]
查看完整版本: phpcms v9添加热门搜索关键词的方法