mysql sum(if())和count(if())的用法說明
mysql sum(if())和count(if())的用法
SELECT SUM(if(category=1,size,0)) ,COUNT(if(category=1,true,null)) FORM t_file;
解析
sum(if(category=1,size,0))
sum函數返回一個值類型的數值,如果category=1,則返回size,如果category不等於1就返回0。
count(if(category=1,true,null))
count函數返回一個佈爾值類型的數值,如果category=1,返回true,如果category不等於1返回null,如果寫成count(If(category=1,1,0) 則返回的全是true,也就是說全都會計數,而count()間斷內容是true還是null,如果不是null就計數,如果是null就不計數。
所以count(if())的寫法應該是count(if(表達式表達式,true,null));
mysql 聚合函數 根據條件求和 sum(if())
SELECT p.Id Id, p.ImgUrl ImgUrl, p.Title Title, p.ReferOutPrice ReferOutPrice, e.`Status`, SUM(IF(e.`Status`=1 OR e.`Status`=2, ed.Number,0)) FROM Product p LEFT JOIN EBOrdersDetails ed ON p.id = ed.ProductId LEFT JOIN EBOrders e ON ed.PurchaseNo = e.PurchaseNo WHERE p.StoreId = 143 AND p.`Status` >-1 GROUP BY p.Id
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- MySql分頁時使用limit+order by會出現數據重復問題解決
- mysql語法之DQL操作詳解
- MySQL新手入門進階語句匯總
- 理解MySQL查詢優化處理過程
- 為什麼MySQL分頁用limit會越來越慢