将2个sql查询语句合并为一个?

时间:2015-12-08 13:23:04

标签: sql sql-server tsql

美好的一天。我在Query中有一个语句,它从临时表中选择字段并将其插入到最终表中。它看起来像这样:

INSERT INTO [dbo].[Final]([DateStamp],[TIME],[DATE],[USER_LOGIN],[USER_NAME],[PRODUCT_NAME  ],[MODEL_NAME   ],[OPERATION    ],[CLIENT_IP    ],[OBJECT   ],[VIEW_TYPE    ],[VIEW])
SELECT CONCAT([DATE],'', [TIME]) AS [DateStamp],[TIME],[DATE],[USER_LOGIN],[USER_NAME],[PRODUCT_NAME    ],[MODEL_NAME   ],[OPERATION    ],[CLIENT_IP    ],[OBJECT   ],[VIEW_TYPE    ],[VIEW]
FROM #Temp

但之后我必须改变决赛桌:

UPDATE [dbo].[Final] SET [DateStamp] = SUBSTRING([DateStamp],1,10)+' '+SUBSTRING([DateStamp],11,15)
ALTER TABLE [dbo].[Final] ALTER COLUMN [DateStamp] DATETIME

有没有办法在select语句中执行此操作。临时表未使用DateStamp列创建,因为我正在读取文本文件,并且不希望它开始将数据插入该列。所以我创建它,但只需要将这两个部分加在一起,我不确定如何。谢谢

1 个答案:

答案 0 :(得分:0)

是。您可以在select中转换值。如果我理解正确:

INSERT INTO [dbo].[Final]([DateStamp],[TIME],[DATE],[USER_LOGIN],[USER_NAME],[PRODUCT_NAME  ],[MODEL_NAME   ],[OPERATION    ],[CLIENT_IP    ],[OBJECT   ],[VIEW_TYPE    ],[VIEW])
    SELECT CAST(STUFF(CONCAT([DATE],'', [TIME]), 11, 0, ' ') as DATETIME) AS [DateStamp],
           [TIME],[DATE],[USER_LOGIN],
           [USER_NAME],[PRODUCT_NAME    ],[MODEL_NAME   ],[OPERATION    ],
           [CLIENT_IP    ],[OBJECT   ],[VIEW_TYPE    ],[VIEW]
    FROM #Temp;

如果时间正确,您可以添加datetime

注:

我意识到你正在做insert而不是select into。您应该将列设置为正确的类型。如果您使用的是SQL Server 2012+,请使用try_convert()而不是convert()来避免错误。