Как создать таблицу Temp с помощью SELECT * INTO tempTable FROM CTE Query

У меня есть запрос MS SQL CTE, из которого я хочу создать временную таблицу. Я не уверен, как это сделать, поскольку оно дает ошибку Invalid Object name.

Ниже приведен весь запрос для справки

SELECT * INTO TEMPBLOCKEDDATES FROM 
;with Calendar as (
    select EventID, EventTitle, EventStartDate, EventEndDate, EventEnumDays,EventStartTime,EventEndTime, EventRecurring, EventStartDate as PlannedDate
    ,EventType from EventCalender
    where EventActive = 1 AND LanguageID =1 AND EventBlockDate = 1
    union all
    select EventID, EventTitle, EventStartDate, EventEndDate, EventEnumDays,EventStartTime,EventEndTime, EventRecurring, dateadd(dd, 1, PlannedDate)
    ,EventType from Calendar
    where EventRecurring = 1
        and dateadd(dd, 1, PlannedDate) <= EventEndDate 
)
select EventID, EventStartDate, EventEndDate, PlannedDate as [EventDates], Cast(PlannedDate As datetime) AS DT, Cast(EventStartTime As time) AS ST,Cast(EventEndTime As time) AS ET, EventTitle
,EventType from Calendar
where (PlannedDate >= GETDATE()) AND ',' + EventEnumDays + ',' like '%,' + cast(datepart(dw, PlannedDate) as char(1)) + ',%'
    or EventEnumDays is null
order by EventID, PlannedDate
option (maxrecursion 0)

Я бы оценил точку в правильном направлении или могу создать временную таблицу из этого запроса CTE

Ответ 1

Пример DDL

create table #Temp
(
    EventID int, 
    EventTitle Varchar(50), 
    EventStartDate DateTime, 
    EventEndDate DatetIme, 
    EventEnumDays int,
    EventStartTime Datetime,
    EventEndTime DateTime, 
    EventRecurring Bit, 
    EventType int
)

;WITH Calendar
AS (SELECT /*...*/)

Insert Into #Temp
Select EventID, EventStartDate, EventEndDate, PlannedDate as [EventDates], Cast(PlannedDate As datetime) AS DT, Cast(EventStartTime As time) AS ST,Cast(EventEndTime As time) AS ET, EventTitle
,EventType from Calendar
where (PlannedDate >= GETDATE()) AND ',' + EventEnumDays + ',' like '%,' + cast(datepart(dw, PlannedDate) as char(1)) + ',%'
    or EventEnumDays is null

Убедитесь, что таблица удалена после использования

If(OBJECT_ID('tempdb..#temp') Is Not Null)
Begin
    Drop Table #Temp
End

Ответ 2

Действительно формат может быть довольно простым - иногда нет необходимости предопределять временную таблицу - он будет создан из результатов выбора.

Select FieldA...FieldN 
into #MyTempTable 
from MyTable

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

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

Ответ 3

SELECT ... INTO должен быть выбран в CTE.

;WITH Calendar
     AS (SELECT /*... Rest of CTE definition removed for clarity*/)
SELECT EventID,
       EventStartDate,
       EventEndDate,
       PlannedDate                   AS [EventDates],
       Cast(PlannedDate AS DATETIME) AS DT,
       Cast(EventStartTime AS TIME)  AS ST,
       Cast(EventEndTime AS TIME)    AS ET,
       EventTitle,
       EventType
INTO TEMPBLOCKEDDATES /* <---- INTO goes here*/        
FROM   Calendar
WHERE  ( PlannedDate >= Getdate() )
       AND ',' + EventEnumDays + ',' LIKE '%,' + Cast(Datepart(dw, PlannedDate) AS CHAR(1)) + ',%'
        OR EventEnumDays IS NULL
ORDER  BY EventID,
          PlannedDate
OPTION (maxrecursion 0) 

Ответ 4

Как использовать TempTable в хранимой процедуре?

Вот шаги:

CREATE TEMP TABLE

-- CREATE TEMP TABLE 
Create Table #MyTempTable (
    EmployeeID int
);

INSERT TEMP ВЫБЕРИТЕ ДАННЫЕ В ТАБЛИЦУ TEMP

-- INSERT COMMON DATA
Insert Into #MyTempTable
Select EmployeeID from [EmployeeMaster] Where EmployeeID between 1 and 100

SELECT TEMP TABLE (теперь вы можете использовать этот запрос выбора)

Select EmployeeID from #MyTempTable

ОКОНЧАТЕЛЬНЫЙ ШАГ УДАЛИТЬ ТАБЛИЦУ

Drop Table #MyTempTable

Надеюсь, это поможет. Простой и понятный:)