weixin_46724576 2022-05-30 15:17 采纳率: 100%
浏览 13
已结题

GBase 8a 中group by grouping sets函数怎么使用?

GBase 8a 中group by grouping sets函数怎么使用?

  • 写回答

1条回答 默认 最新

  • 生命之源; 2022-05-30 15:22
    关注

    GROUP BY GROUPING SETS (A,B,C) (A、B、C 代表语法中的“(…)”)
    首先对(A)进行 GROUP BY,然后对(B)进行 GROUP BY,然后对(C)进行 GROUP BY,最后将所有结果合并在一起(相当于 UNION ALL 操作),如果 n 个字段或表达式中的一个或多个在某一分组中不出现在 GROUP BY 后面,用 NULL 代替不出现的字段或表达式。

    样例
    数据样例
    简单的学生科目考试记录。

    gbase> select * from score;
    +--------+---------+-------+
    | name | subject | score |
    +--------+---------+-------+
    | 王海 | 语文 | 86 |
    | 王海 | 数学 | 83 |
    | 王海 | 英语 | 93 |
    | 陶俊 | 语文 | 88 |
    | 陶俊 | 数学 | 84 |
    | 陶俊 | 英语 | 94 |
    | 刘可 | 语文 | 80 |
    | 刘可 | 数学 | 86 |
    | 刘可 | 英语 | 88 |
    | 李春 | 语文 | 89 |
    | 李春 | 数学 | 80 |
    | 李春 | 英语 | 87 |
    +--------+---------+-------+
    12 rows in set (Elapsed: 00:00:00.01)

    获得学生和学科各自的汇总结果
    gbase> select name,subject,sum(score) from score group by grouping sets(name,subject);
    +--------+---------+------------+
    | name | subject | sum(score) |
    +--------+---------+------------+
    | NULL | 语文 | 343 |
    | NULL | 数学 | 333 |
    | NULL | 英语 | 362 |
    | 王海 | NULL | 262 |
    | 陶俊 | NULL | 266 |
    | 刘可 | NULL | 254 |
    | 李春 | NULL | 256 |
    +--------+---------+------------+
    7 rows in set (Elapsed: 00:00:00.02)
    多个Sets之间也是union all关系。本例就简单的将上一个用例的2个条件,拆分一下。结果是一样的。

    gbase> select name,subject,sum(score) from score group by grouping sets((name),(subject));
    +--------+---------+------------+
    | name | subject | sum(score) |
    +--------+---------+------------+
    | NULL | 语文 | 343 |
    | NULL | 数学 | 333 |
    | NULL | 英语 | 362 |
    | 王海 | NULL | 262 |
    | 陶俊 | NULL | 266 |
    | 刘可 | NULL | 254 |
    | 李春 | NULL | 256 |
    +--------+---------+------------+
    7 rows in set (Elapsed: 00:00:00.02)

    gbase> select name,subject,sum(score) from score group by grouping sets(name,(name,subject));
    +--------+---------+------------+
    | name | subject | sum(score) |
    +--------+---------+------------+
    | 王海 | 语文 | 86 |
    | 王海 | 数学 | 83 |
    | 王海 | 英语 | 93 |
    | 陶俊 | 语文 | 88 |
    | 陶俊 | 数学 | 84 |
    | 陶俊 | 英语 | 94 |
    | 刘可 | 语文 | 80 |
    | 刘可 | 数学 | 86 |
    | 刘可 | 英语 | 88 |
    | 李春 | 语文 | 89 |
    | 李春 | 数学 | 80 |
    | 李春 | 英语 | 87 |
    | 王海 | NULL | 262 |
    | 陶俊 | NULL | 266 |
    | 刘可 | NULL | 254 |
    | 李春 | NULL | 256 |
    +--------+---------+------------+
    16 rows in set (Elapsed: 00:00:00.04)

    如上第二个例子中,第一部分是name, 第二部分是(name,subject)两个字段一起。

    注意,不考虑重复,也就是你可以写多个name。

    gbase> select name,subject,sum(score) from score group by grouping sets(name,name,subject);
    +--------+---------+------------+
    | name | subject | sum(score) |
    +--------+---------+------------+
    | NULL | 语文 | 343 |
    | NULL | 数学 | 333 |
    | NULL | 英语 | 362 |
    | 王海 | NULL | 262 |
    | 陶俊 | NULL | 266 |
    | 刘可 | NULL | 254 |
    | 李春 | NULL | 256 |
    | 王海 | NULL | 262 |
    | 陶俊 | NULL | 266 |
    | 刘可 | NULL | 254 |
    | 李春 | NULL | 256 |
    +--------+---------+------------+
    11 rows in set (Elapsed: 00:00:00.03)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 6月10日
  • 已采纳回答 6月2日
  • 创建了问题 5月30日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。