如何理解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