博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ThinkPHP 统计查询
阅读量:6844 次
发布时间:2019-06-26

本文共 1358 字,大约阅读时间需要 4 分钟。

  hot3.png

统计查询

在应用中我们经常会用到一些统计数据,例如当前所有(或者满足某些条件)的用户数、所有用户的最大积分、学生的平均成绩等等,ThinkPHP 为这些统计操作提供了一系列的内置方法:

  1. :统计数据行数
  2. :统计某个字段最大数据
  3. :统计某个字段最小数据
  4. :统计某个字段平均数据
  5. :统计某个字段数据之和

上述统计查询方法都是独立的方法且支持连贯操作。

count()

count() 方法用于统计数据行数。

例子:

public function read(){    $Dao = M('User');    // 获取用户数:    $userCount = $Dao->count();    // 添加条件:    $userCount2 = $Dao->where('uid > 10')->count();    $this->assign('userCount', $userCount);    $this->display();}

上例中,两个查询语句实际执行的 SQL 为:

SELECT COUNT(*) AS tp_count FROM user LIMIT 1 SELECT COUNT(*) AS tp_count FROM user WHERE uid > 10 LIMIT 1

可以在模板中直接输出得到的统计数据:

共有用户 {$userCount} 人。

max()

max() 方法用于统计某个字段最大数据。

统计用户最大积分例子:

$maxScore = $Dao->max('score');

实际执行的 SQL 为:

SELECT MAX(score) AS tp_max FROM user LIMIT 1

min()

min() 统计某个字段最小数据。

获取积分大于 0 的用户的最小积分例子:

$minScore = $Dao->where('score>0')->min('score');

实际执行的 SQL 为:

实际执行SQL:SELECT MIN(score) AS tp_min FROM user WHERE score>0 LIMIT 1

avg()

avg() 统计某个字段平均数据。

获取用户的平均积分例子:

$avgScore = $Dao->avg('score');

实际执行的 SQL 为:

SELECT AVG(score) AS tp_avg FROM user LIMIT 1

sum()

sum() 统计某个字段数据之和。

统计积分排名前 10 名用户的积分之和:

$sumScore = $Dao->order('score DESC')->limit('10')->sum('score');

实际执行的 SQL 为:

SELECT SUM(score) AS tp_sum FROM user ORDER BY score DESC LIMIT 10

所有的统计查询如 select() 方法一样。均支持连贯操作的使用,根据实际情况添加不同的查询条件。

参考阅读

  1. 《》系列教程
  2. ThinkPHP Where 条件
  3. ThinkPHP 连贯操作

转载于:https://my.oschina.net/sunYwp/blog/791390

你可能感兴趣的文章
MS SQL 批量给存储过程/函数授权
查看>>
并发集合(九)使用原子 arrays
查看>>
上传应用
查看>>
Cocos2d-x-v3动作体系
查看>>
ChargeSystem——One,Two,Three
查看>>
【ASP.NET】验证控件
查看>>
FZU 1752 a^b%c
查看>>
[华为机试真题]72.操作系统任务调度问题
查看>>
解决scrollView上subView下移20point问题的一种方式
查看>>
前端面试之关于HTTP协议
查看>>
利用 Matplotlib 绘制数据图形(二)
查看>>
iOS概念攻坚之路(二):Runtime
查看>>
关于前端请求发送时间时而长时而短问题(stalled a lot)
查看>>
Python 工匠:编写条件分支代码的技巧
查看>>
记一次前端面试经历
查看>>
带你探索JUnit 5.4
查看>>
<暗时间> 时间, 不在于你拥有多少, 而在于你怎样使用
查看>>
单例 - iOS
查看>>
戛纳电影节百花齐放,中国明星衣着品味紧跟时尚前沿
查看>>
mysql 存储emoji表情
查看>>