mysql如何實現每隔N行生成一個匯總行-創新互聯

小編給大家分享一下mysql如何實現每隔N行生成一個匯總行,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

專注于為中小企業提供網站建設、成都網站設計服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業白山免費做網站提供優質的服務。我們立足成都,凝聚了一批互聯網行業人才,有力地推動了上千家企業的穩健成長,幫助中小企業通過網站建設實現規模擴充和轉變。



處理這種每隔N行生成一個匯總行的需求,一共有三種方式

  • select when c is null then '匯總' else '' end s,ifnull(c,sumc) c from (  

  •     select ceil(id/3) l,c,null sumc  

  •     from   

  •     (  

  •         select @id:=@id+1 id, t1.* from t t1,(select @id:=0) vars    

  •     ) t2  

  •     union all    

  •     select ceil(id/3) l,null,from   

  •     (  

  •         select @id1:=@id1+1 id, t1.* from t t1,(select @id1:=0) vars    

  •     ) t3  

  •     group by l  

  • ) t order by l,ifnull(c,'9999'); 


  • 結果:


  • mysql如何實現每隔N行生成一個匯總行

  • 第二招,數字輔助表補全. 性能較好. 計算匯總行,理解稍微復雜.



  • 先增加一個數字輔助表 nums


    1. table(int null)delimiter $$

    2.  procedure pCreateNumscnt )

    3.     declare s default;

    4. truncate  nums    while s=        intoselect;

    5. set=+;

    6. end;

    7.  $$

    8. ;

    9. create(intbegin

    10. int  1    table;

    11. insert  nums  s    while s2=        intoselect+from;

    12. set=*;

    13. end;

    14.  $$

    15. ;


  • 初始化數字輔助表


  • select s,ifnull(c,cc) c  

  • from (    

  •     select     

  •     when rn is null then '匯總' else '' end s,     

  •     t4.c,  

  •     if(mod(t3.id,4)!=0 ,when @total=-1 then @total:=t4.c else @total:=@total+t4.c end,@total) cc,  

  •     when mod(t3.id,4)=0 then @total:=-1 else null end     

  •     from (    

  •         select * from nums where id<=    

  •         (select (ceil(from t )    

  •     ) t3    

  •     join (    

  •         select     

  •         when mod(@rn+1,4)=0 then @rn:=@rn+2 else @rn:=@rn+1 end rn ,    

  •         t1.* from t t1,(select @rn:=0,@total:=0) vars      

  •     ) t4 on(t3.id=t4.rn)    

  • ) result;    


  • 這個理解稍微有點復雜,


  • 第二招改進版本


    1. select when id is null then '匯總' else '' end s,from (  

    2.     select @id:=@id+1 id, t1.* from t t1,(select @id:=0) vars      

    3. ) t2  

    4. group by ceil(t2.id/3),t2.id with rollup;  



以上是“mysql如何實現每隔N行生成一個匯總行”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯-成都網站建設公司行業資訊頻道!

本文名稱:mysql如何實現每隔N行生成一個匯總行-創新互聯
地址分享:http://m.kartarina.com/article30/eoipo.html

成都網站建設公司_創新互聯,為您提供營銷型網站建設響應式網站定制開發Google網站制作用戶體驗

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

h5響應式網站建設
主站蜘蛛池模板: 永久免费av无码网站yy| 国产成人无码久久久精品一| 久久av无码专区亚洲av桃花岛| 无码中文字幕乱在线观看| 无码人妻精品一区二区三区久久久 | 国产精品无码A∨精品影院| 成人无码WWW免费视频| 亚洲熟妇无码av另类vr影视| 一区二区三区人妻无码 | 久久无码人妻精品一区二区三区| 亚洲日产无码中文字幕| 欧美性生交xxxxx无码影院∵| 亚洲真人无码永久在线| 毛片亚洲AV无码精品国产午夜| 国产AV一区二区三区无码野战| 成人免费无码大片a毛片| 人妻夜夜添夜夜无码AV| 亚洲V无码一区二区三区四区观看| 成人免费一区二区无码视频| 亚洲av无码一区二区三区天堂古代| 亚洲v国产v天堂a无码久久| mm1313亚洲国产精品无码试看| 无码孕妇孕交在线观看| 成年无码av片完整版| 亚洲伊人成无码综合网| 日日摸日日碰人妻无码| 亚洲AV无码一区二区三区性色| 久久精品aⅴ无码中文字字幕不卡| 国产精品无码成人午夜电影| 无码人妻一区二区三区精品视频| 亚洲爆乳AAA无码专区| 亚洲精品无码成人| 中文字幕av无码无卡免费| 久久成人无码国产免费播放| 亚洲欧洲日产国码无码久久99| 中文字幕无码免费久久| 国产AⅤ无码专区亚洲AV| 东京热人妻无码一区二区av| 国产强伦姧在线观看无码| 成人无码精品1区2区3区免费看| 精品乱码一区内射人妻无码|