注意:dede_archives这是系统默认的数据库表,如果你修改过表前缀dede_,请自行更改表名。在以下示例的标签中,有一部分只写出了SQL语句,具体的完整标签写法请参考:织梦SQL标签调用方法。具体的可以百度一下

共有文章:** 篇

{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 count(mid) 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}

24小时发布的新文章:

select count(id)+0 as total from dede_archives where UNIX_TIMES*****P() - pubdate < 86400 and arcrank >=0;

//86400 是 3600 * 24,也就是24小时发布的新文章。

当天发布的最新文章

SELECT count(ID) as count from dede_archives where pubdate > UNIX_TIMES*****P( FROM_UNIXTIME(UNIX_TIMES*****P(), '%Y-%m-%d 00:00:00'))  limit 1;

当天审核通过的最新文章

SELECT count(ID) as count from dede_archives where pubdate > UNIX_TIMES*****P( FROM_UNIXTIME(UNIX_TIMES*****P(), '%Y-%m-%d 00:00:00')) and arcrank >0  limit 1;

当天审核通过的最新文章

where to_days(curdate())=to_days(from_unixtime(pubdate)) and arcrank=0

本月更新:**篇

{dede:sql sql="SELECT count( ID ) AS c FROM cn_archives WHERE FROM_UNIXTIME( pubdate, '%m' ) = month (curdate( )) "} ○ 本月更新:<strong>[field:c /]</strong> 篇;{/dede:sql}

文章收藏次数:

[field:ID runphp='yes']$dsql = new dedesql();$dsql -> SetQuery("select count(*) as c from cn_member_stow where aid=".@me);$nic_row = $dsql -> getone();@me=$nic_row['c'];[/field:ID]

统计指定栏目及所有下属分支栏目内的文章数

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}

增加栏目文章统计功能

第一种方法:

修改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']);

}

调用方法:{dede:countclass typeid='栏目编号'/}

第二种方法:

修改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'];

}

调用方法:[field:id function='GetTotalArc(@me)'/]

dedecms万能SQL标签使用方法大全的更多相关文章

  1. 经典SQL语句使用方法大全

    一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数 ...

  2. 经典SQL语句使用方法大全(自留用)

    一.基础 1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份 ...

  3. 非常实用的织梦dede所有标签调用方法大全

    关键描述调用标签: <meta name="keywords" content="{dede:field name='keywords'/}">&l ...

  4. DEDECMS万能标签{dede:sql}使用教程详解

    http://www.dede58.com/a/dedebq/2015/0226/1737.html 1.首页在后台单页文档管理里添加一个单页文档,内容编辑框输入你要的内容生成. 2.在需要调用单页文 ...

  5. 织梦DedeCms用SQL语句调用数据库任意内容方法

    织梦DedeCms给我们提供了大量调用标签,供我们调用各种数据,但提供再多的标签,也有满足不了我们的时候,这时我们可以用SQL语句,灵活调用我们需要的内容. 如何任意调用数据库中的内容呢?先举个例子: ...

  6. Oracle SQL语句性能优化方法大全

    Oracle SQL语句性能优化方法大全 下面列举一些工作中常常会碰到的Oracle的SQL语句优化方法: 1.SQL语句尽量用大写的: 因为oracle总是先解析SQL语句,把小写的字母转换成大写的 ...

  7. Mybatis笔记 - SQL标签方法

    Mpper.xml映射文件中定义了操作数据库的sql,并且提供了各种标签方法实现动态拼接sql.每个sql是一个statement,映射文件是mybatis的核心. 一.内容标签 1.NamePlac ...

  8. Mybatis总结一之SQL标签方法

    ---恢复内容开始--- 定义:mapper.xml映射文件中定义了操作数据库的sql,并且提供了各种标签方法实现动态拼接sql.每个sql是一个statement,映射文件是mybatis的核心. ...

  9. {dede:sql}标签的用法

    sql标签可以称得上是个万能标签了,查询数据库将其输出,这里介绍一些关于这个标签的用法: 1.用来输出统计内容,这个是不错的,举个例子,我们来统计下总共发了多少的文章,思路就是输出dede_addon ...

随机推荐

  1. 微信小程序 更新版本操作

    1.小程序的启动方式: 冷启动----小程序首次打开或销毁后再次被打开 热启动----小程序打开后,在一段时间内(目前:5分钟)再次被打开,此时会将后台的小程序切换到前台. 2.根据以上两种启动方式, ...

  2. 风炫安全WEB安全学习第二十二节课 DOM型XSS讲解

    风炫安全WEB安全学习第二十二节课 DOM型XSS讲解 Dom型XSS演示 通过Javascript,可以重构整个HTML文档,你可以添加.移除.改变或重排页面上的项目 要改变页面的某个东西,Java ...

  3. MySQL中in('5,6,7')只取第一个id为5对应的数据的思考

    通过阅读本文你可以更好的理解两个知识点: 1.#{}与${}在实际项目中的使用,避免在项目中使用不当造成不可预知的Bug; 2.MySQL中in里面如果是字符串的话,为什么只取第一个对应的数据,eg: ...

  4. 十八般武艺玩转GaussDB(DWS)性能调优:路径干预

    摘要:路径生成是表关联方式确定的主要阶段,本文介绍了几个影响路径生成的要素:cost_param, scan方式,join方式,stream方式,并从原理上分析如何干预路径的生成. 一.cost模型选 ...

  5. Spring Security OAuth2.0认证授权五:用户信息扩展到jwt

    历史文章 Spring Security OAuth2.0认证授权一:框架搭建和认证测试 Spring Security OAuth2.0认证授权二:搭建资源服务 Spring Security OA ...

  6. leetcode-242有效字母异位词

    题目 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词. 示例 1: 输入: s = "anagram", t = "nagaram&quo ...

  7. 7.prometheus之查询API

    一.格式概述 二.表达式查询 2.1 Instant queries(即时查询) 2.2 范围查询 三.查询元数据 3.1 通过标签匹配器找到度量指标列表 3.2 获取标签名 3.3 查询标签值 四. ...

  8. 安装Tomcat 9

    文章目录 访问Tomcat官网 选择下载所需的软件包 安装Tomcat 测试安装 访问Tomcat官网 Tomcat官方的下载地址为:https://tomcat.apache.org/downloa ...

  9. 【Linux】snmp在message中报错: /etc/snmp/snmpd.conf: line 311: Error: ERROR: This output format has been de

    Apr 17 17:36:17 localhost snmpd[2810]: /etc/snmp/snmpd.conf: line 311: Error: ERROR: This output for ...

  10. 【Oracle】查看表空间是否为自动扩展

    查看指定的表空间是否为自动扩展 SQL>   select file_name,autoextensible,increment_by from dba_data_files where tab ...