如何使用SQL server 2005组合2列?
问题是DateTime存储在一列中,毫秒存储在另一列中。
我想将毫秒添加到DateTime列中,使其具有更准确的DateTime。
我需要使用这个DateTime来查询精确到毫秒的记录。
知道吗?
我需要用添加的值替换DateTime。
SELECT *
FROM TABLENAME
WHERE [DateTime] >= '2011-04-12 12:00:00 AM'
AND [DateTime] <= '2011-05-25 3:35:04 AM'
并运行查询。
好吧,首先解决你的问题:
SELECT DATEADD(millisecond,<milliscolumn>,<datetimecolumn>) from <table>
然后提交一份错误报告,这些报告无论如何都应该存储在一列中。
您可以根据您的示例查询来执行此操作,但请注意,这会破坏服务器使用索引的可能性:
SELECT * FROM TABLENAME WHERE
DATEADD(millisecond,[MillisecondColumn],[DateTime]) between
'2011-04-12T12:00:00' AND '2011-05-25T03:35:04'
如果这是一个大表,那么索引可能很重要。如果您无法更改填充此数据的内容,则可能需要将此计算作为持久化计算列添加到此表中,然后对其进行索引和查询。
请注意,我已经用一个BETWEEN
替换了您的两个比较,并调整了日期时间字符串,使它们不受区域设置的影响。
SELECT(第A列+第B列)AS第Z列FROM表
可能会解决你的问题。