Sqlserver
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Sqlserver

Tính số bản ghi cho mỗi ngày giữa 2 ngày

Cải thiện câu trả lời của Dale K, tôi khuyên bạn nên sử dụng bảng hoặc hàm kiểm đếm, vì bảng này thường hiệu quả hơn.

Tôi đã sử dụng cái nổi tiếng của Itzik Ben-Gan bên dưới:

DECLARE @StartDate date = '2020-11-01', @EndDate date = '2021-02-22';

  WITH
    L0 AS ( SELECT 1 AS c 
            FROM (VALUES(1),(1),(1),(1),(1),(1),(1),(1),
                        (1),(1),(1),(1),(1),(1),(1),(1)) AS D(c) ),
    L1 AS ( SELECT 1 AS c FROM L0 AS A CROSS JOIN L0 AS B ),
    L2 AS ( SELECT 1 AS c FROM L1 AS A CROSS JOIN L1 AS B ),
    Nums AS ( SELECT ROW_NUMBER() OVER(ORDER BY (SELECT NULL)) AS rownum
              FROM L2 )
    Date_Range_T (d_range) AS (
      SELECT TOP(DATEDIFF(day, @StartDate, @EndDate) + 1)
          DATEADD(day, rownum - 1, @StartDate) AS d_range,
          DATEADD(day, rownum, @StartDate) AS d_rangeNext
      FROM Nums
    )
SELECT d_range, COUNT(Id) AS Total 
FROM Date_Range_T 
LEFT JOIN tbl_Support_Requests R
    ON R.CreatedDate >= T.d_range AND R.CreatedDate < T.d_rangeNext
GROUP BY d_range
ORDER BY d_range ASC


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. sql địa lý để dbgeography?

  2. Phương pháp tốt nhất để loại bỏ phần thời gian của datetime trong SQL Server

  3. Mục đích của việc sao chép dữ liệu là gì?

  4. Không thể đăng nhập vào SQL Server + Xác thực SQL Server + Lỗi:18456

  5. Tạo hồ sơ thư cơ sở dữ liệu trong SQL Server (T-SQL)