Подтвердить что ты не робот

Количество SQL для каждой даты

У меня есть следующая потребность

У меня есть таблица регистрации, которая регистрирует som, сгенерированные каждый день.

Теперь мне нужно вывести отчет за количество отведений за каждый день за последние 10 дней.

Предположим, что таблица выглядит так:

tbl_leads
id int,
first_name nvarchar(100),
last_name nvarchar(100),
created_date datetime

И мне нужно подсчитать количество потенциальных клиентов за каждый день, всего 10 дней. Итак, результирующий набор должен выглядеть примерно так:

counted_leads | count_date
5             | 2009-04-30
7             | 2009-04-29
5             | 2009-04-28
7             | 2009-04-27

... и т.д.

Кто-нибудь знает, как это сделать наилучшим образом? Мое текущее решение повторяется с foreach в С#, но я бы очень хотел передать его на sql-сервере вместо sp.

4b9b3361

Ответ 1

Вы можете использовать:

Select
     count(created_date) as counted_leads,
     created_date as count_date
from
     table
group by
     created_date

Ответ 2

Поле created_date datetime, поэтому вам нужно будет отключить время до того, как группировка будет работать, если вы хотите перейти по дате:

SELECT COUNT(created_date), created_date 
FROM table 
WHERE DATEDIFF(created_date, getdate()) < 10
GROUP BY convert(varchar, created_date, 101)

Ответ 3

Наиболее эффективно выполнять агрегацию по целому числу, а затем конвертировать обратно в datetime для презентации.

select 
    cast(daybucket - 1 as datetime) as count_date,
    counted_leads
from 
    (select 
         cast(created_date as int) as DayBucket,
         count(*) as counted_leads
     from mytable
     group by cast(created_date as int) ) as countByDay

Ответ 4

Когда вы бросаете DateTime в int, он "обрезается" в полдень, вы можете удалить этот день так:

cast (DATEADD (DAY, DATEDIFF (DAY, 0, created_date), 0) как int) как DayBucket

Ответ 5

Select count(created_date) total
     , created_dt
  from table
group by created_date
order by created_date desc

Ответ 6

CREATE PROCEDURE [dbo].[sp_Myforeach_Date]
    -- Add the parameters for the stored procedure here
    @SatrtDate as DateTime,
    @EndDate as dateTime,
    @DatePart as varchar(2),
    @OutPutFormat as int 
AS
BEGIN
    -- SET NOCOUNT ON added to prevent extra result sets from
    -- interfering with SELECT statements.
    Declare @DateList Table
    (Date varchar(50))

    WHILE @SatrtDate<= @EndDate
    BEGIN
    INSERT @DateList (Date) values(Convert(varchar,@SatrtDate,@OutPutFormat))
    IF Upper(@DatePart)='DD'
    SET @SatrtDate= DateAdd(dd,1,@SatrtDate)
    IF Upper(@DatePart)='MM'
    SET @SatrtDate= DateAdd(mm,1,@SatrtDate)
    IF Upper(@DatePart)='YY'
    SET @SatrtDate= DateAdd(yy,1,@SatrtDate)
    END 
    SELECT * FROM @DateList
END

Просто поставьте этот код и вызовите SP таким образом

exec sp_Myforeach_Date @SatrtDate='03 Jan 2010',@EndDate='03 Mar 2010',@DatePart='dd',@OutPutFormat=106

Спасибо Сувабрата Рой ICRA Online Ltd. Kolkata

Ответ 7

У меня был аналогичный вопрос, однако у меня был столбец Convert (date, mydatetime). Мне пришлось изменить наилучший ответ следующим образом:

Select
     count(created_date) as counted_leads,
     Convert(date,created_date) as count_date 
from table
group by Convert(date,created_date)