sql >> Databasteknik >  >> RDS >> Sqlserver

SQL-gruppering efter månad och år

SELECT CAST(MONTH(date) AS VARCHAR(2)) + '-' + CAST(YEAR(date) AS VARCHAR(4)) AS Mjesec, SUM(marketingExpense) AS SumaMarketing, SUM(revenue) AS SumaZarada 
FROM [Order]
WHERE (idCustomer = 1) AND (date BETWEEN '2001-11-3' AND '2011-11-3')
GROUP BY CAST(MONTH(date) AS VARCHAR(2)) + '-' + CAST(YEAR(date) AS VARCHAR(4))

Eller som @40-Love nämnde kan du kasta med inledande nollor:

GROUP BY 
  CAST(YEAR(date) AS VARCHAR(4)) + '-' + right('00' + CAST(MONTH(date) AS VARCHAR(2)), 2) 


  1. URL-strängformat för att ansluta till Oracle-databas med JDBC

  2. Ta bort en ansluten användare från ett Oracle 10g-databasschema

  3. Hur man tar bort en del av strängen i Oracle

  4. Vad är skillnaden mellan RANK och DENSE_RANK i SQL?