gpt4 book ai didi

sql - 使用 min(datetime) 了解 SQL Server 行为

转载 作者:行者123 更新时间:2023-12-04 18:32:07 27 4
gpt4 key购买 nike

(长话短说,这只是我的一个愚蠢假设,我确定列是日期时间但它不是 - 所以不要指望在这个问题中找到任何有趣的东西,将它留在这里以便 dems 得到他正确接受的答案)

我写了一个像这样的简单查询:

SELECT ID, MIN(DateMadeActive) AS DateMadeActive
FROM RecordStateField WHERE RecordStatusID in (2, 3)
GROUP BY ID

其中 DateMadeActive 是日期时间列。这返回了我的预期:

ID  DateMadeActive
1 20/06/2011 16:15:04
2 20/06/2011 16:14:28

现在我将它插入到一个新表中,但是将 MIN(DateMadeActive) 的结果插入到另一个表的日期时间列中时出现了这个错误:

Msg 8115, Level 16, State 2, Line 1
Arithmetic overflow error converting expression to data type datetime.

所以为了测试这个,我将我的选择更改为:

SELECT ID, CAST(Min(DateMadeActive) as datetime) AS DateMadeActive
FROM RecordStateField WHERE RecordStatusID in (2, 3)
GROUP BY ID

同样的异常(exception)。我可以这样写并让它工作:

SELECT ID, CONVERT(datetime, Min(DateMadeActive), 103) AS DateMadeActive
FROM RecordStateField WHERE RecordStatusID in (2, 3)
GROUP BY ID

所以我可以让它工作,但这让我很困惑。 documentation for MIN(expression) 表示返回类型应与表达式相同,但似乎正在发生的是 MIN(datetime) 正在返回 nvarchar(255)。我可以通过运行这个来确认这一点:

SELECT ID, Min(DateMadeActive) AS DateMadeActive
INTO TestTable
FROM RecordStateField WHERE RecordStatusID in (2, 3)
GROUP BY ID

而且我可以看到 DateMadeActive 列的类型为 nvarchar(255)。有人对此有所了解吗?只是 MSDN 中的文档错误?

最佳答案

在我看来,[RecordStateField] 中的 DateMadeActive 是一个 VARCHAR(255) 字段。你能发布表格定义吗?

我问这个是因为 MIN() 以前从未为我更改过类型。因此,如果结果是 VARCHAR(255),则输入似乎也必须是 VARCHAR(255)

关于sql - 使用 min(datetime) 了解 SQL Server 行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6414700/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com