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://www.kartarina.com/article30/eoipo.html

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

廣告

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

h5響應式網站建設
主站蜘蛛池模板: 亚洲日韩精品无码专区加勒比☆| 国产精品无码制服丝袜| 无码精品黑人一区二区三区| 久久久久亚洲AV片无码下载蜜桃| 精品亚洲A∨无码一区二区三区| 亚洲精品无码不卡在线播放| 国产免费无码AV片在线观看不卡| av潮喷大喷水系列无码| 中文字幕精品无码一区二区三区| 精品久久久久久中文字幕无码 | 久久无码av三级| 久久亚洲精品无码gv| 亚洲一区二区三区国产精品无码| 无码人妻H动漫中文字幕 | 亚洲一区二区无码偷拍| 日韩人妻无码一区二区三区久久99 | 无套内射在线无码播放| 无码精品人妻一区二区三区影院| 无码福利写真片视频在线播放| 中文字幕av无码专区第一页 | 亚洲国产精品成人AV无码久久综合影院 | 亚洲av中文无码乱人伦在线r▽ | 性无码一区二区三区在线观看| 精品无码国产AV一区二区三区| 中文字幕乱偷无码av先锋蜜桃| 无码AV中文字幕久久专区| 亚洲av无码一区二区三区网站 | 国产在线无码制服丝袜无码| 50岁人妻丰满熟妇αv无码区| 亚洲爆乳无码一区二区三区| 最新中文字幕AV无码不卡| 亚洲av无码专区在线观看素人| 性饥渴少妇AV无码毛片| 精品久久久久久无码人妻中文字幕 | 少妇极品熟妇人妻无码| 国产精品无码亚洲一区二区三区 | 国产AV无码专区亚洲AV男同| 国产精品无码成人午夜电影| 亚洲AV人无码激艳猛片| 精品无码一区二区三区在线| 亚洲heyzo专区无码综合|