Временная таблица не создается

Я пытаюсь создать 2 временные таблицы в следующем коде. Хотя мое условие говорит о создании временной таблицы из оператора else, для tmp2 оно говорит, что таблица уже создана. Я делаю это, потому что я хочу объединить данные из 2 временных таблиц, есть ли у них данные или нет.

Следующий скрипт не создает таблицу ##tmp2 независимо от условия else в следующем запросе...

DECLARE @@TOTALCOUNT  INT 
DECLARE @@DECRIPTION VARCHAR(100)
DECLARE @@ST VARCHAR(100)
DECLARE @@ZP VARCHAR(100)
DECLARE @@CT VARCHAR(100)
DECLARE @@GN  VARCHAR(100)

SET @@ST = 'IA'
SET @@CT = 'JOHNSTON'
SET @@ZP = '50131'
SET @@GN = 'FEMALE'

BEGIN TRY
    DROP TABLE ##TMP1;
    DROP TABLE ##TMP2;          

END TRY

BEGIN CATCH

    SET @@DECRIPTION =  ' VEHICLES ARE SOLD DURING LAST 3  MONTHS '

    SET @@TOTALCOUNT = ( SELECT COUNT(*)  FROM [TALK TRACK RAP].DBO.CARSEXCEL
    WHERE [SALE_DATE] >  DATEADD( DAY, -90 ,CONVERT (DATE , '01/01/2013',103)) 
    AND [SALE_DATE] < CONVERT (DATE , '01/01/2013',103)) ;

    SELECT  MAKE , ( (100 * COUNT(*)) /@@TOTALCOUNT ) CN , 
    CONVERT(VARCHAR, ( (100 * COUNT(*)) /@@TOTALCOUNT ))+ ' % ' + MAKE + @@DECRIPTION AS TALK INTO ##TMP1
    FROM [TALK TRACK RAP].DBO.CARSEXCEL
    WHERE [SALE_DATE] >  DATEADD( DAY, -90 ,CONVERT (DATE , '01/01/2013',103)) 
    AND [SALE_DATE] < CONVERT (DATE , '01/01/2013',103)
    GROUP BY MAKE 
END CATCH


IF @@ST IS NULL
BEGIN

    SET @@TOTALCOUNT = (SELECT COUNT(*) FROM [TALK TRACK RAP].DBO.CARSEXCEL
    WHERE [SALE_DATE] >  DATEADD( DAY, -90 ,CONVERT (DATE , '01/01/2013',103)) 
    AND [SALE_DATE] < CONVERT (DATE , '01/01/2013',103)
    AND  STATE= @@ST  )

    SET @@DECRIPTION =  ' VEHICLES ARE SOLD DURING LAST 3  MONTHS IN ' +  @@ST+ ' STATE '

    SELECT  MAKE , ( (100 * COUNT(*)) / @@TOTALCOUNT ) CN ,
    CONVERT(VARCHAR, ( (100 * COUNT(*)) /@@TOTALCOUNT ))+ ' % ' +MAKE + @@DECRIPTION  AS TALK INTO ##TMP2
    FROM [TALK TRACK RAP].DBO.CARSEXCEL
    WHERE [SALE_DATE] >  DATEADD( DAY, -90 ,CONVERT (DATE , '01/01/2013',103)) 
    AND [SALE_DATE] < CONVERT (DATE , '01/01/2013',103)
    AND  STATE= @@ST
    GROUP BY MAKE ;
END 

if @@ST IS NOT NULL
BEGIN

    IF EXISTS ( SELECT * FROM sys.tables WHERE name LIKE '##TMP2%' ) 
    DROP TABLE ##TMP2
    CREATE TABLE ##TMP2 (MAKE VARCHAR(30), CN VARCHAR(30), TALK VARCHAR(30))
END

Как я могу это исправить?

1 ответ

Временные таблицы не отображаются в sys.tables. Вот простой способ проверить временную таблицу:

IF OBJECT_ID('tempdb..#TMP2') IS NOT NULL DROP TABLE #TMP2
GO
Другие вопросы по тегам