美好的一天。我在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列创建,因为我正在读取文本文件,并且不希望它开始将数据插入该列。所以我创建它,但只需要将这两个部分加在一起,我不确定如何。谢谢
答案 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;
如果时间正确,您可以添加date
和time
。
注:
我意识到你正在做insert
而不是select into
。您应该将列设置为正确的类型。如果您使用的是SQL Server 2012+,请使用try_convert()
而不是convert()
来避免错误。