SQL SELECT DISTINCT 语句
- {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}
在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(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}
本月点击排行榜
以上代码当然可以自定义,48小时点击:dayviews、day=2 本月点击:monthviews、day=48。
- {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}
希望以上内容对你有所帮助!如果还有其他问题,请随时提问。 各类知识收集 拥有多年CMS企业建站经验,对 lecms, classcms, fastadmin, pbootcms, phpcms, eyoucms, yzmcms, PHP, xunruicms, jizhicms, dedecms, wordpress, hkcms, yzncms, 等各类cms的相互转化,程序开发,网站制作,bug修复,程序杀毒,插件定制都可以提供最佳解决方案。