MySQL聚合函数的原理及作用
admin
2023-04-20 13:22:58
0

下文我给大家简单讲讲关于MySQL聚合函数的原理及作用,大家之前了解过相关类似主题内容吗?感兴趣的话就一起来看看这篇文章吧,相信看完MySQL聚合函数的原理及作用对大家多少有点帮助吧。 

以下是我们经常要用的一些聚合函数,请谨慎使用,注意sql_mode 模式设置对查询结果的影响,如果sql_mode=' ',那么:
select create_time,test_name,max(moneys) from test_table group by test_name;  查询不报错,但可能与预想结果不一样,时间与最大值不匹配,之前见有开发这样写过,如果sql_mode=‘only_full_group_by’,以上sql 会报错。

  1. avg()   求平均值
    select test_name,avg(moneys) from test_table group by test_name;       按人名分组求平均金额
    +-----------+---------------+
    | test_name | avg(moneys)   |
    +-----------+---------------+
    | 哈罗德    | 550000.175000 |
    | 格温      | 170015.130000 |
    | 班尼      | 915016.630000 |
    +-----------+---------------+

  2. max()   求最大值
    select test_name,max(moneys) from test_table group by test_name;       按人名分组求最大金额
    +-----------+-------------+
    | test_name | max(moneys) |
    +-----------+-------------+
    | 哈罗德    |  1000000.23 |
    | 格温      |   170030.13 |
    | 班尼      |  1660003.13 |
    +-----------+-------------+

  3. min()   求最小值
    select test_name,min(moneys) from test_table group by test_name;        按人名分组求最小金额
    +-----------+-------------+
    | test_name | min(moneys) |
    +-----------+-------------+
    | 哈罗德    |   100000.12 |
    | 格温      |   170000.13 |
    | 班尼      |   170030.13 |
    +-----------+-------------+

  4. sum()   求和
    select test_name,sum(moneys) from test_table group by test_name;       按人名分组求总金额
    +-----------+-------------+
    | test_name | sum(moneys) |
    +-----------+-------------+
    | 哈罗德    |  1100000.35 |
    | 格温      |   340030.26 |
    | 班尼      |  1830033.26 |
    +-----------+-------------+

  5. count() 求行数
    select count() from test_table;     直接求总行数
    +----------+
    | count() |
    +----------+
    |        6 |
    +----------+

select test_name,count() from test_table group by test_name;         按人名分组求频率
+-----------+----------+
| test_name | count() |
+-----------+----------+
| 哈罗德    |        2 |
| 格温      |        2 |
| 班尼      |        2 |
+-----------+----------+

select test_name,count(distinct test_name) from test_table group by test_name;        先去重,后按人名分组求频率
+-----------+---------------------------+
| test_name | count(distinct test_name) |
+-----------+---------------------------+
| 哈罗德    |                         1 |
| 格温      |                         1 |
| 班尼      |                         1 |
+-----------+---------------------------+

6.group_concat()  拼接数据
select test_name,group_concat(test_id),avg(moneys) from test_table group by test_name;  按人名分组拼接id    
+-----------+-----------------------+---------------+
| test_name | group_concat(test_id) | avg(moneys)   |
+-----------+-----------------------+---------------+
| 哈罗德    | 1,2                   | 550000.175000 |
| 格温      | 3,5                   | 170015.130000 |
| 班尼      | 4,6                   | 915016.630000 |
+-----------+-----------------------+---------------+

7.计算每日访问量
select * from t1;
+------+-------+------+
| year | month | day  |
+------+-------+------+
| 2000 |    01 |   01 |
| 2000 |    01 |   20 |
| 2000 |    01 |   30 |
| 2000 |    02 |   02 |
| 2000 |    02 |   23 |
| 2000 |    02 |   23 |
+------+-------+------+

SELECT year,month,BIT_COUNT(BIT_OR(1<GROUP BY year,month;
+------+-------+------+
| year | month | days |
+------+-------+------+
| 2000 |    01 |    3 |
| 2000 |    02 |    2 |
+------+-------+------+

大家觉得MySQL聚合函数的原理及作用这篇文章怎么样,是否有所收获。如果想要了解更多相关,可以继续关注我们的行业资讯板块。


相关内容

热门资讯

【第一资讯】“喜扣游戏真的有挂... 家人们!今天小编来为大家解答喜扣游戏透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...
【今日要闻】“美猴王拼三张开挂... 网上科普关于“美猴王拼三张有没有挂”话题很是火热,小编也是针对美猴王拼三张作*弊开挂的方法以及开挂对...
终于明白“福建十三水真的有挂吗... 有 亲,根据资深记者爆料福建十三水是可以开挂的,确实有挂(咨询软件无需打...
最新引进“纸上战争到底是不是挂... 有 亲,根据资深记者爆料纸上战争是可以开挂的,确实有挂(咨询软件无需打开...
今日重磅消息“广西老友玩开挂神... 有 亲,根据资深记者爆料广西老友玩是可以开挂的,确实有挂(咨询软件无需打...
玩家攻略科普“超稳牛牛到底有挂... 家人们!今天小编来为大家解答超稳牛牛透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很...
今日重大发现“新九天牛牛开挂器... 今日重大发现“新九天牛牛开挂器?”(详细开挂教程)您好,新九天牛牛这个游戏其实有挂的,确实是有挂的,...
终于了解“趣友到底有挂吗?”(... 您好:趣友这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏中打...
我来教教您“大金牙麻将有挂吗?... 网上科普关于“大金牙麻将有没有挂”话题很是火热,小编也是针对大金牙麻将作*弊开挂的方法以及开挂对应的...