PHPCMS默认仅支持栏目点击排行榜,在V9版本中,也可以通过数据库来调用全站点击排行。
{pc:get sql="SELECT DISTINCT url,title,views FROM v9_news,v9_hits WHERE v9_news.id = substring(v9_hits.hitsid,5) ORDER BY v9_hits.views DESC" num="10" } <ul> {loop $data $v} <li><a href="{$v['url']}">{$v[title]}</a><span>点击数:{$v[views]}</span></li> {/loop} </ul> {/pc}
SQL SELECT DISTINCT 语句
在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值。关键词 DISTINCT 用于返回唯一不同的值。
语法:
SELECT DISTINCT 列名称 FROM 表名称
SQL中SUBSTRING的语法说明
SQL中SUBSTRING用于返回字符、二进制、文本或图像表达式的一部分,下面将为您详细介绍SQL中SUBSTRING的语法说明,供您参考。
功能:返回字符、二进制、文本或图像表达式的一部分
语法:SUBSTRING ( expression, start, length )
SQL中substring 函数是用来抓出一个栏位资料中的其中一部分。这个函数的名称在不同的资料库中不完全一样:
参数:
expression 字符串、二进制字符串、文本、图像、列或包含列的表达式。请勿使用包含聚合函数的表达式。
start 整数或可以隐式转换为 int 的表达式,指定子字符串的开始位置。
length 整数或可以隐式转换为 int 的表达式,指定子字符串的长度,SQL中SUBSTRING的返回值:
如果 expression 是一种支持的字符数据类型,则返回字符数据。如果 expression 是一种支持的二进制数据类型,则返回二进制数据。如果 start = 1,则子字符串从表达式的第一个字符开始。
以下是PHPCMSV9版本之前的全站点击排行的方法,有兴趣的朋友可以看看。
要修改的代码文件
打开phpcmsmodulescontentclassescontent_tag.class.php 在里面添加以下代码:
/** * sitehits站点点击排行 * @param $data */ function sitehits($data){ if(empty($data['siteid'])) return false; $siteid = intval($data['siteid']); $this->hits_db = pc_base::load_model(‘hits_model’); $category_content = getcache(‘category_content’,'commons’); $catid = ”; //获取站点下所有栏目ID foreach($category_content as $key=>$val){ if($val==$siteid){ $catid .= $comma.$key; $comma=','; } } //获取点击排行 $r = $this->hits_db->select(‘catid in(‘.$catid.’)',’hitsid’,$data['limit'],$data['order']); $return = array(); $sitemodel_model_db = pc_base::load_model(‘sitemodel_model’); $this->db_config = pc_base::load_config(‘database’); $tablepre = $this->db_config['default']['tablepre']; foreach($r as $key){ preg_match_all('/-(d+)-/',$key['hitsid'],$modelid); $id = substr($key['hitsid'],(strpos($key['hitsid'],'-',2)+1)); $tablename = $sitemodel_model_db->get_one(array('modelid'=>$modelid[1][0]),'tablename'); $this->db->table_name = $tablepre.$tablename['tablename']; $return[] = array_merge($return,$this->db->get_one(array(‘id’=>$id))); } return $return; }
全站点击排行榜的调用
所有时间点击排行榜
{pc:content action=”sitehits” siteid=”4″ num=”10″ order=”views DESC” cache=”3600″} <ul> {loop $data $r} <li><a href="{$r[url]}">{$r[title]}</a></li> {/loop} </ul> {/pc}
当天点击排行榜
{php $historytime = mktime(0, 0, 0, date('m', TIME), date('d', TIME), date('Y', TIME));} {get sql="select p.*,t.* from phpcms_content p,phpcms_content_count t where p.contentid=t.contentid and p.status=99 and p.inputtime>=$historytime order by t.hits desc" rows="10" return="v"} <a herf="{$v[url]}" >{$v[title]}</a>点击数:{$v[hits]} {/get}
本周点击排行榜
<?php $week = gmdate('w', TIME) - 1; $week = $week != -1 ? $week : 6; $historytime = mktime(0, 0, 0, date('m', TIME), date('d', TIME) - $week, date('Y', TIME)); ?> {get sql="select p.*,t.* from phpcms_content p,phpcms_content_count t where p.contentid=t.contentid and p.status=99 and p.inputtime>=$historytime order by t.hits desc" rows="10" return="v"} <a herf="{$v[url]}" >{$v[title]}</a>点击数:{$v[hits]} {/get}
本月点击排行榜
{php $historytime = mktime(0, 0, 0, date('m', TIME), 1, date('Y', TIME));} {get sql="select p.*,t.* from phpcms_content p,phpcms_content_count t where p.contentid=t.contentid and p.status=99 and p.inputtime>=$historytime order by t.hits desc" rows="10" return="v"} <a herf="{$v[url]}" >{$v[title]}</a>点击数:{$v[hits]} {/get}
以上代码当然可以自定义,48小时点击:dayviews、day=2 本月点击:monthviews、day=48。