Server : nginx/1.20.1 System : Linux iZ2ze9ojcl78uluczwag69Z 4.18.0-240.22.1.el8_3.x86_64 #1 SMP Thu Apr 8 19:01:30 UTC 2021 x86_64 User : www ( 1000) PHP Version : 7.3.28 Disable Function : passthru,exec,system,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv Directory : /www/wwwroot/0531yanglao.com/vendor/topthink/think-orm/src/db/concern/ |
<?php // +---------------------------------------------------------------------- // | ThinkPHP [ WE CAN DO IT JUST THINK ] // +---------------------------------------------------------------------- // | Copyright (c) 2006~2019 http://thinkphp.cn All rights reserved. // +---------------------------------------------------------------------- // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 ) // +---------------------------------------------------------------------- // | Author: liu21st <liu21st@gmail.com> // +---------------------------------------------------------------------- declare (strict_types = 1); namespace think\db\concern; use think\db\exception\DbException; use think\db\Raw; /** * 聚合查询 */ trait AggregateQuery { /** * 聚合查询 * @access protected * @param string $aggregate 聚合方法 * @param string|Raw $field 字段名 * @param bool $force 强制转为数字类型 * @return mixed */ protected function aggregate(string $aggregate, $field, bool $force = false) { return $this->connection->aggregate($this, $aggregate, $field, $force); } /** * COUNT查询 * @access public * @param string|Raw $field 字段名 * @return int */ public function count(string $field = '*'): int { if (!empty($this->options['group'])) { // 支持GROUP if (!preg_match('/^[\w\.\*]+$/', $field)) { throw new DbException('not support data:' . $field); } $options = $this->getOptions(); $subSql = $this->options($options) ->field('count(' . $field . ') AS think_count') ->bind($this->bind) ->buildSql(); $query = $this->newQuery()->table([$subSql => '_group_count_']); $count = $query->aggregate('COUNT', '*'); } else { $count = $this->aggregate('COUNT', $field); } return (int) $count; } /** * SUM查询 * @access public * @param string|Raw $field 字段名 * @return float */ public function sum($field): float { return $this->aggregate('SUM', $field, true); } /** * MIN查询 * @access public * @param string|Raw $field 字段名 * @param bool $force 强制转为数字类型 * @return mixed */ public function min($field, bool $force = true) { return $this->aggregate('MIN', $field, $force); } /** * MAX查询 * @access public * @param string|Raw $field 字段名 * @param bool $force 强制转为数字类型 * @return mixed */ public function max($field, bool $force = true) { return $this->aggregate('MAX', $field, $force); } /** * AVG查询 * @access public * @param string|Raw $field 字段名 * @return float */ public function avg($field): float { return $this->aggregate('AVG', $field, true); } }