用SQL統(tǒng)計增加一行或者一列的合計

-- 用SQL統(tǒng)計增加一行或者一列的合計

-- .方法一
WITH STUDENT AS
 (SELECT 'STUDENT1' NAME1, 1 VALUE FROM DUAL
  UNION ALL
  SELECT 'STUDENT2' NAME1, 2 VALUE FROM DUAL
  UNION ALL
  SELECT 'STUDENT3' NAME1, 3 VALUE FROM DUAL)
SELECT * FROM STUDENT
UNION ALL
SELECT '合計', SUM(VALUE) FROM STUDENT;

-- .方法2
WITH STUDENT AS
 (SELECT 'STUDENT1' NAME1, 1 VALUE FROM DUAL
  UNION ALL
  SELECT 'STUDENT2' NAME1, 2 VALUE FROM DUAL
  UNION ALL
  SELECT 'STUDENT3' NAME1, 3 VALUE FROM DUAL)
SELECT DECODE(GROUPING(NAME1), 1, '合計', NAME1), SUM(VALUE) FROM STUDENT GROUP BY ROLLUP((NAME1, VALUE));

-- DECODE(條件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值);
-- GROUPING函數(shù)可以接受一列,返回0或者1。
-- 如果列值為空,那么GROUPING()返回1;
-- 如果列值非空,那么返回0。
-- GROUPING只能在使用ROLLUP或CUBE的查詢中使用。當需要在返回空值的地方顯示某個值時,GROUPING()就非常有用。

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容