卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章64334本站已运行4115

聚合函数有哪些?

在研发中,我们常常有类似的市场需求:统计数据某个字段的最大值、最小值、 平均值等等。为此,MySQL中提供了聚合函数去实现这些功能。所谓聚合,就是将多行汇总成一行;其实,所有的生成函数均如此——输出多行,输入一行。生成函数具备自动滤空的功能,若某一个值NULL,那么会自动将其过滤使其不参与运算。

聚合函数采用规则:

只有SELECT子句和HAVING子句、ORDER BY子句中能采用生成函数。比如,在WHERE子句中使用生成函数是错误的。

接下来,我们学习常用生成函数。

1.1、count()

统计表中数据的行数或者统计数据指定列于其值不为NULL的数据个数

查询有多少该表中有多少人

MySQL命令:

select count(*) from student;

1.2、max()

计算指定列于的最大值,如果选定列是字符串类型则采用字符串排序运算

查询该学生表中年纪最小的学生

MySQL命令:

select max(age) from student;

1.3、min()

计算指定列于的最小值,如果选定列是字符串类型则采用字符串排序运算

查询该学生表年纪最小的学生 MySQL命令:

select sname,min(age) from student;

1.4、sum()

排序选定列于的数值和,如果选定列于类型不是数值类型则计算结果为0

查询该学生表年纪的总和 MySQL命令:

select sum(age) from student;

1.5、avg()

排序指定列的平均值,如果指定列于类型不是数值类型则计算结果为

查询该学生表年纪的平均数 MySQL命令:

select avg(age) from student;

2.其他常用函数

这里我就不一一举例了,基本混个面熟,以后使用再细说

2.1、时间函数

SELECT NOW();
SELECT DAY (NOW());
SELECT DATE (NOW());
SELECT TIME (NOW());
SELECT YEAR (NOW());
SELECT MONTH (NOW());
SELECT CURRENT_DATE();
SELECT CURRENT_TIME();
SELECT CURRENT_TIMESTAMP();
SELECT ADDTIME('14:23:12','01:02:01');
SELECT DATE_ADD(NOW(),INTERVAL 1 DAY);
SELECT DATE_ADD(NOW(),INTERVAL 1 MONTH);
SELECT DATE_SUB(NOW(),INTERVAL 1 DAY);
SELECT DATE_SUB(NOW(),INTERVAL 1 MONTH);
SELECT DATEDIFF('2019-07-22','2019-05-05');

2.2、字符串函数

--连接函数
SELECT CONCAT ()
--SELECT INSTR ();
--统计数据长度
SELECT LENGTH();

2.3、数学函数

-- 绝对值
SELECT ABS(-136);
-- 向上取整
SELECT FLOOR(3.14);
-- 向下取整
SELECT CEILING(3.14);

卓越飞翔博客
上一篇: MySQL数据表查询入门教程
下一篇: 数据库时间函数
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏