zoukankan      html  css  js  c++  java
  • 如何理解group by语句

    参考文章:

      https://blog.csdn.net/hao1066821456/article/details/69556644

    如何实现一对多关系,得到一行多列的显示方式:

      group by可以理解为,group之后生成一个虚拟表,group的字段对应的只有一行,而其他的字段整合成一行,再把这些字段进行聚合如count、sum、max、min。

      下面的例子理解为:如A选项,对每一个大行中的小行进行case when,然后对结果进行取max,不是A选项的都是空值,取max就得到A选项的实际值。

    select eq.id,eq.content,eqo.code,eqo.optioncontent from ExamQuestion eq
    right join ExamQuestionOption  eqo 
    on eq.id=eqo.qid
    order by eqo.qid,eqo.code
    
    select id
    ,MAX(case code when 'A' then optioncontent else '' end) A
    ,MAX(case code when 'B' then optioncontent else '' end) B
    ,MAX(case code when 'C' then optioncontent else '' end) C
    ,MAX(case code when 'D' then optioncontent else '' end) D
     from (
    select eq.id,eq.content,eqo.code,eqo.optioncontent from ExamQuestion eq
    right join ExamQuestionOption  eqo 
    on eq.id=eqo.qid
    ) T 
    group by id
    order by id

     

  • 相关阅读:
    BZOJ 1014 火星人prefix
    BZOJ 1013 球形空间产生器
    BZOJ 1012 最大数
    BZOJ 1011 遥远的行星
    BZOJ 1010 玩具装箱
    BZOJ 1009 GT考试
    BZOJ 1008 越狱
    BZOJ 1007 水平可见直线
    BZOJ 1006 神奇的国度
    Luogu 1450 [HAOI2008]硬币购物
  • 原文地址:https://www.cnblogs.com/zhaoyihao/p/9713241.html
Copyright © 2011-2022 走看看