MySQL的sum()函數

來源:互聯網
上載者:User

標籤:nbsp   bsp   imp   post   遇到   esc   lis   cts   實現   

如,這是一個關於使用者參加活動,每個活動會給這位使用者評分的一個表:

使用者1參加了A活動,評分100;

使用者2參加了B活動,評分98,又參加了D活動,評分10;

使用者3參加了C活動,評分99

需求:把以上四條資料按照每個使用者的 總分 降序排列

SQL:

SELECT SUM(score),user_id,campaign_id FROM 表名 GROUP BY (user_id) ORDER BY SUM(score) DESC ;

結果為:

完成需求,以下是實際應用遇到的小問題:

**Dao.xml :

需要注意:因為sum()是一個函數,所以取值時要用map接收,但是 我們這個需求是要降序的,map 又是無序的,用map接收豈不是做了無用功?不用擔心,在Dao裡我們再封裝一層:

**Dao.java :

把他用ArrayList來接收,Map做泛型,這樣就不怕它的順序變化了,順便貼一下實作類別裡的取值方法:

**ServiceImpl . java :

foreach迴圈,但如果取sum(score)時,直接像上一行取contacts_id一樣   ,轉String類型運行是會報錯的,需要藉助Integer來做轉換,這樣取到的值才是正確不會報異常的。

 

MySQL的sum()函數

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.