dedecms实用的统计sql语句标签收集
作者:难耐五更寒 | 来源:互联网 | 2014-05-27 15:58
这两天,突然又见到论坛里求统计用代码的帖子多起来,这里发几个常用的DEDE统计SQL标签,如果还有什么其它需要的,请跟帖说明,日后继续补充……另:希望各位提问的兄弟们,先自行搜索一下论坛,也许你的问题可以在以往的帖子里找到答案~~·注意dede_archi
这两天,突然又见到论坛里求统计用代码的帖子多起来,这里发几个常用的DEDE统计SQL标签,如果还有什么其它需要的,请跟帖说明,日后继续补充……
另:希望各位提问的兄弟们,先自行搜索一下论坛,也许你的问题可以在以往的帖子里找到答案~~
·注意 dede_archives 这个前缀是默认的 请将dede改成你的数据库前缀 ·共有文章:** 篇
{dede:sql sql="select count(ID) as c from dede_archives where
channel=1"}·共有文章:[field:c /]篇{/dede:sql}
·共有图集:** 个
{dede:sql sql="select count(ID) as c from dede_archives where
channel=2"}·共有图集:[field:c /]个{/dede:sql}
·共有软件:** 个
{dede:sql sql="select count(ID) as c from dede_archives where
channel=3"}·共有软件:[field:c /]个{/dede:sql}
·共有评论:**条
{dede:sql sql="select count(ID) as c from
dede_feedback"}·共有评论:[field:c /]条{/dede:sql}
·共有会员:**名
{dede:sql sql="select count(ID) as c from dede_member
"}·共有会员:[field:c /]名{/dede:sql}
·文章阅读:** 人次
{dede:sql sql="select sum(click) as c from
dede_archives"}文章阅读:[field:c /]人次{/dede:sql}
·今日更新:**篇
{dede:sql sql="SELECT count( ID ) AS c FROM dede_archives WHERE
pubdate > UNIX_TIMESTAMP( CURDATE( ) ) "}今日更新:[field:c
/]篇{/dede:sql}
·统计指定栏目及所有下属分支栏目内的文章数
1、修改include/inc_functions.php文件,增加函数如下: function
GetTotalArc($tid){
$dsql = new DedeSql(false);
$sql = TypeGetSunID($tid,$dsql);
$row = $dsql->GetOne("Select count(ID) as dd From dede_archives
where {$sql}");
return $row['dd'];
}2、调用方法,在需要修改的模板页插入如下代码(其中的3是栏目ID,根据你的实际情况修改)
{dede:field function='GetTotalArc(3)'/}
补充一点:
如果在栏目模板页面上调用,可以用这个写法,统计当前栏目内的文章数
{dede:field name='ID' function='GetTotalArc(@me)'/}
·栏目文章统计功能
使用 dedecms 的runphp 接口 编写一个 函数.利用channel标签的ID变量或得。
函数。
function GetChannelArticleNum($id){
if(!$id || !is_numeric($id)) return 0;
$dsql = new DedeSql();
require_once(dirname(__FILE__)."/inc_channel_unit_functions.php");
$sql = TypeGetSunID($id,$dsql);
$dsql -> SetQuery("Select count(*) as c From dede_archives where
{$sql}");
$row = $dsql -> GetOne();
return $row['c'];
}
将该函数放入 inc_functions.php 中
示例调用方法.
{dede:channel type='top' row='8'} | [field:typename/] ([field:ID
runphp='yes'] @me =
GetChannelArticleNum(@me);[/field:ID]){/dede:channel}
效果见本站首页菜单。
改变 | [field:typename/] ([field:ID runphp='yes'] @me =
GetChannelArticleNum(@me);[/field:ID]) 可获得更多形式。
如果你使用该方法没有效果,请打开 inc_typelink.php(以下是在 dedecms
v3.1的情况,4.x版本请对应查看)
查找函数 function GetChannelList 体内的
if($row=$this->dsql->GetArray())
{
在 //处理同级栏目中,当前栏目的样式 上加上一行 $row['id'] = $row['ID'];
这是dedecms 里面一个奇怪的问题。 [field:ID /] 经常获得不到值,有时又是可以的,而用$row['id'] =
$row['ID']; 后即可用 [field:ID /]获得, 可能是 $row['ID']
在某个地方没打引号被作为了一个常量。。。。。。
·增加栏目文章统计功能
第一种方法:
1、 修改include/inc_arcpart_view.php文件
找到function ParseTemplet()函数
修改为:
function ParseTemplet()
{
if(!is_array($this->dtp->CTags)) return "";
foreach($this->dtp->CTags as $tagid=>$ctag)
{
$tagname = $ctag->GetName();
//countclass 统计栏目文章数量
if( $tagname == "countclass" ){
$tid = $ctag->GetAtt("typeid");
$row = $this->dsql->GetOne("Select count(ID) as dd From
dede_archives where typeid='$tid' and arcrank<>-1");
$this->dtp->Assign($tagid,$row['dd']);
}
2、在网页上调用方法
{dede:countclass typeid=栏目编号/}
例如:
{dede:countclass typeid='2'/}
第二种方法(由 正牌执子之手339709 提供):
1、修改include/inc_functions.php文件,增加函数如下:
function GetTotalArc($tid){
$dsql = new DedeSql(false);
$row = $dsql->GetOne("Select count(ID) as dd From dede_archives
where typeid='$tid'");
return $row['dd'];
}
2、调用方法
[field:id function='GetTotalArc(@me)'/]
推荐阅读
-
本文详细介绍了 JavaScript 中创建对象的几种常见方式,包括对象字面量、构造函数和 Object.create 方法,并提供了示例代码和属性描述符的解释。 ...
[详细]
蜡笔小新 2024-12-22 16:40:51
-
本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ...
[详细]
蜡笔小新 2024-12-22 16:20:33
-
-
本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ...
[详细]
蜡笔小新 2024-12-22 14:43:35
-
本文介绍了解决在Windows操作系统或SQL Server Management Studio (SSMS) 中遇到的“microsoft.ACE.oledb.12.0”提供程序未注册问题的方法,特别针对Access Database Engine组件的安装。 ...
[详细]
蜡笔小新 2024-12-21 15:21:22
-
本章详细介绍SP框架中的数据操作方法,包括数据查找、记录查询、新增、删除、更新、计数及字段增减等核心功能。通过具体示例和详细解析,帮助开发者更好地理解和使用这些方法。 ...
[详细]
蜡笔小新 2024-12-21 13:27:32
-
本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ...
[详细]
蜡笔小新 2024-12-20 21:22:27
-
本文探讨了如何在Hive(基于Hadoop)环境中编写类似SQL的语句,以去除字段中的空格。特别是在处理邮政编码等数据时,去除特定位置的空格是常见的需求。 ...
[详细]
蜡笔小新 2024-12-20 19:08:43
-
本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ...
[详细]
蜡笔小新 2024-12-20 18:58:01
-
本文详细介绍了如何解决 Microsoft SQL Server 中用户 'sa' 登录失败的问题。错误代码为 18470,提示该帐户已被禁用。我们将通过 Windows 身份验证方式登录,并启用 'sa' 帐户以恢复其访问权限。 ...
[详细]
蜡笔小新 2024-12-20 18:41:13
-
本文详细介绍了如何在PHPStudy环境下配置DVWA( Damn Vulnerable Web Application ),并利用该平台进行SQL注入和XSS攻击的练习。通过此过程,读者可以熟悉常见的Web漏洞及其利用方法。 ...
[详细]
蜡笔小新 2024-12-20 18:22:20
-
本文详细介绍如何使用 Apache Spark 执行基本任务,包括启动 Spark Shell、运行示例程序以及编写简单的 WordCount 程序。同时提供了参数配置的注意事项和优化建议。 ...
[详细]
蜡笔小新 2024-12-20 18:01:20
-
KMP算法是处理字符串匹配的一种高效算法它首先用O(m)的时间对模板进行预处理,然后用O(n)的时间完成匹配。从渐进的意义上说,这样时间复 ...
[详细]
蜡笔小新 2024-12-20 09:52:11
-
本文介绍如何利用SQL Server Profiler工具来监控特定数据库的操作,并获取执行这些操作的客户端计算机名和账户名。步骤包括创建新的跟踪、配置跟踪属性以及设置列筛选器以精确过滤数据。 ...
[详细]
蜡笔小新 2024-12-19 16:28:55
-
本文详细介绍了如何在PHP中实现基于概率的随机抽奖功能。通过实例代码,解释了抽奖逻辑、奖品设置及结果统计的方法。适合PHP开发者参考学习。 ...
[详细]
蜡笔小新 2024-12-22 16:39:29
-
本文旨在纠正关于 MySQL 中 IN 语句是否使用索引的常见误解。许多人认为 IN 语句的索引使用与字符串长度有关,实际上,影响因素更为复杂,包括数据分布和 MySQL 版本等因素。 ...
[详细]
蜡笔小新 2024-12-22 12:34:36
-