我需要varchar
在我的表中插入一个。表中的类型是 adatetime
所以我需要转换它。我不认为这会是一个大问题,但是它一直插入1900-01-01 00:00:00.000
而不是我想要的日期。当我使用转换后的日期进行选择时,它会显示正确的日期。
我将向您展示代码:
INSERT INTO Item (CategoryId, [Date], Content, CreatedOn)
SELECT
CategoryId, Convert(datetime, '28/11/2012', 103), Content, GetDate()
FROM
Item i
JOIN
Category c ON i.CategoryId = c.Id
JOIN
Division d ON d.Id = c.DivisionId
WHERE
Date = Convert(datetime, '31/03/2005', 103)
AND d.Id = '142aaddf-5b63-4d53-a331-8eba9b0556c4'
where 子句完美运行,并为我提供了我需要的过滤项目,所有数据都正确插入,除了转换后的日期。就像我说的 1900-...
如果我只是这样选择:
SELECT CategoryId, Convert(datetime, '28/11/2012', 103), Content, GetDate()
FROM Item i
JOIN Category c ON i.CategoryId = c.Id
JOIN Division d ON d.Id = c.DivisionId
WHERE Date = Convert(datetime, '31/03/2005', 103) AND d.Id = '142aaddf-5b63-4d53-a331-8eba9b0556c4'
我得到正确的日期是:2012-11-28 00:00:00.000
。我尝试使用不同的转换,例如:
Convert(datetime, '20121128')
但这只会带来同样的问题。任何人看到我做错了什么?
谢谢