1

假设您有下表:

CREATE TABLE [dbo].[Test]
(
    [Value] [sql_variant] NOT NULL
)

并让我们插入一些 DATETIME2 值:

INSERT INTO [dbo].[Test]
(
    [Value]
)
VALUES
(
    SYSUTCDATETIME()
)

现在,让我们看看结果:

SELECT
    [Value],
    SQL_VARIANT_PROPERTY([Value], 'BaseType') AS BaseType
FROM
    [dbo].[Test]


Value                     BaseType
-----------------------------------
2019-11-25 19:39:43.274   datetime2
2019-11-25 19:43:49.735   datetime2

为什么值会被截断?

4

1 回答 1

4

使用 时sql_variant,您需要具体说明您希望返回的数据类型;否则 SQL Server 将推断显示格式。然而,数据并没有被截断。例如,如果您尝试以下操作,您会看到datetime2(7)结果为Value_DT2

SELECT [Value],
       CONVERT(datetime2,[Value]) AS Value_DT2,
       SQL_VARIANT_PROPERTY([Value], 'BaseType') AS BaseType
FROM [dbo].[Test];
于 2019-11-25T19:54:57.857 回答