2012-07-27 68 views
2

我有一個表字段這個MySQL查詢次數記錄在上年

id sell_date 
a1 27/7/2012 
a1 26/7/2012 
a1 24/7/2012 
a1 24/2/2012 

我想誰擁有個月的計數在當前日期之前一年內的銷售。 結果

a1 = 2

回答

4

假設出售日期是DATE類型:

SELECT COUNT(DISTINCT MONTH(sell_date)) FROM `mytable` 
    WHERE id='a1' 
    AND sell_date>=DATE_SUB(NOW(),INTERVAL 1 YEAR); 

另外,

將刪除id='a1' AND將獲得與任何id關聯的銷售(在上一年期間)的月數。就像這樣:

SELECT COUNT(DISTINCT MONTH(sell_date)) FROM `mytable` 
    WHERE sell_date>=DATE_SUB(NOW(),INTERVAL 1 YEAR); 

就可以得到每一個ID列表和個月與去年與該id銷售數量,就像這樣:

SELECT COUNT(DISTINCT id,MONTH(sell_date)) FROM `mytable` 
    WHERE sell_date>=DATE_SUB(NOW(),INTERVAL 1 YEAR);