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

所属分类: CMS教程 / phpcms 阅读数: 1786
收藏 0 赞 0 分享
通过观察可以发现系统是自带了关键词模型的,只是没有实现。
或许是放在下一个版本里,呵呵~ 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}<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完成!
更多精彩内容其他人还在看

PhpCms内容管理:生成HTML图文教程

PhpCms内容管理中生成HTML的部分的图文教程,下文给大家呈现
收藏 0 赞 0 分享

PhpCms网站公告管理教程

关于PhpCms网站公告管理模块,下文中有详细的图文介绍
收藏 0 赞 0 分享

PhpCms会员管理图文教程

PhpCms的会员管理是如何设置的呢?我们给大家整理了相关的图文教程
收藏 0 赞 0 分享

PhpCms添加栏目图文教程

如何给PhpCms添加栏目,下面我们给大家提供相关的图文教程
收藏 0 赞 0 分享

PhpCms导入模型图文教程

如何将设置PhpCms导入模型,下文有详细的介绍
收藏 0 赞 0 分享

PHPCMS V9 加密规则(经测试相当不错)

PHPCMS V9 加密规则:对输入的密码32位小写 MD5 对输入的密码进行trim过滤,下面有个不错的示例,大家可以参考下
收藏 0 赞 0 分享

phpcms文章页如何显示上一页下一页

phpcms文章页要显示上一页下一页效果并不难,下面的代码大家不妨参考下,或许有所帮助
收藏 0 赞 0 分享

phpcms v9在list_download.html页面中给图片加下载连接的方法

有很多的朋友都不知道在list_download.html页面中怎么给图片加下载连接?其实很简单,下面有个不错的示例,感兴趣的朋友可以参考下
收藏 0 赞 0 分享

phpcms2008后台文章发布文本输入框长度设置方法

经常在新建模型或模型添加字段的时候,所需的文本框的长度各不样同,怎么来设置文本输入框的长度呢?下面有个不错的示例,大家可以感受下
收藏 0 赞 0 分享

完美整合phpcms v9和discuz X3.1实现同步登陆退出论坛免激活

UCenter 作服务端;phpsso 与 Discuz! 分别作 UCenter 的客户端应用;phpsso 与 Discuz! 通过 UCenter 发生交互
收藏 0 赞 0 分享
查看更多