在临时 table 中使用 where 子句

Use where clause in temporary table

我正在尝试在临时 table 中使用 where 子句。其实我用过它,但结果不是真的。试图在 2 个日期之间查找产品,但是当我使用 where 子句时,它得不到任何数据。

CREATE TABLE #TEMPCOZGU
(
    ROW INT,
    TEZGAH VARCHAR(50),
    COZGU VARCHAR(50),  
    PERSONEL VARCHAR(50),
    DATE DATETIME,
    FIRE INT,
    FIRE_METRE NUMERIC(25,6)
)
    INSERT INTO #TEMPCOZGU

select row_number() over(order by TEZGAH) AS ROW, TEZGAH, COZGU, PERSONEL, TARIH, FIRE, FIRE_METRE  
from cozgu_fırelerı 
where tezgah = 'M01' and cozgu = 'SAĞ ALT BAĞLANTI'



SELECT  T1.TEZGAH, T1.COZGU, T1.PERSONEL,T1.FIRE, T1.FIRE_METRE, t1.DATE, T2.DATE AS PREVIOUSDATE, ISNULL(DATEDIFF(DAY, T2.DATE, T1.DATE), 0) AS GUNFARKI  , SUM(MKARE) AS TOPLAMMKARE
FROM #TEMPCOZGU as t1
left outer join #TEMPCOZGU as t2 on t1.row-1 = t2.row
left outer join HALI_TEZGAH AS TE ON T1.TEZGAH = TE.TEZGAH_NO
LEFT OUTER JOIN HALI_GUNLUK_URETIM AS U ON U.TEZGAH = TE.ID 
--WHERE U.TARIH BETWEEN T1.TARIH AND T2.TARIH
GROUP BY  T1.TEZGAH, T1.COZGU, T1.PERSONEL, T1.DATE,T1.FIRE, T1.FIRE_METRE, T2.DATE

drop table #TEMPCOZGU`

如果日期时间值始终将时间设置为“00:00:00”,请尝试

SELECT  T1.TEZGAH, T1.COZGU, T1.PERSONEL,T1.FIRE, T1.FIRE_METRE, t1.DATE, T2.DATE AS PREVIOUSDATE, ISNULL(DATEDIFF(DAY, T2.DATE, T1.DATE), 0) AS GUNFARKI  , SUM(MKARE) AS TOPLAMMKARE
FROM #TEMPCOZGU as t1
left outer join #TEMPCOZGU as t2 on t1.row-1 = t2.row
left outer join HALI_TEZGAH AS TE ON T1.TEZGAH = TE.TEZGAH_NO
LEFT OUTER JOIN HALI_GUNLUK_URETIM AS U ON U.TEZGAH = TE.ID 
WHERE U.TARIH >= T1.TARIH AND  U.TARIH < DateADD (T2.TARIH, INTERVAL 1 DAY)
GROUP BY  T1.TEZGAH, T1.COZGU, T1.PERSONEL, T1.DATE,T1.FIRE, T1.FIRE_METRE, T2.DATE

如果不是这种情况,那么您的 between 应该首先起作用。