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。

推薦閱讀: