php点击排行代码,PHPCMS全站点击排行榜的调用方法"

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" }

{loop $data $v}

{$v[title]} 点击数:{$v[views]}

{/loop}

{/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″}

{loop $data $r}

{$r[title]}

{/loop}

{/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"}

{$v[title]}点击数:{$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"}

{$v[title]}点击数:{$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"}

{$v[title]}点击数:{$v[hits]}

{/get}

以上代码当然可以自定义,48小时点击:dayviews、day=2 本月点击:monthviews、day=48。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值