繁体   English   中英

如何从日期时间转换为SQL中的十六进制存储?

[英]How to convert from datetime to store as Hex in SQL?

我有现有的数据表,其中包括一个十六进制数据字段,该字段实际上是一个日期。

从现有代码中,我知道数据将通过以下方式转换为DATETIME值:

SELECT CAST(0x0000214900000000 AS DATETIME) 

我现在的问题是我需要手动将值插入此类字段,但是我不知道如何为给定的DATETIME生成十六进制值。

我试图插入AS BINARY(8)但是没有返回如上的正确值。

如何执行此转换?

如果您在SQL中执行ALL,这是一个简单示例,所有内存均存在。 您可以在SQL Management Studio中按原样运行它,并且语法对于2008 SQL Server及更高版本应该是正确的。

DECLARE 
    @Date   DateTime = getdate()
,   @Hex    varbinary(8)
;

DECLARE @Temp TABLE ( value varbinary(8) );

INSERT INTO @Temp VALUES (0x0000214900000000),(cast(@Date AS varbinary));

Select
    value
,   cast(value AS DateTime)
from @Temp

SELECT @Hex = cast(cast('2015-04-01' AS DateTime) AS varbinary)

INSERT INTO @Temp VALUES (@Hex)

Select
    value
,   cast(value AS DateTime)
from @Temp

您基本上是将对象类型“投射”到其他对象。 但是对于varbinary,如果要存储它,则还需要指定一个长度。 如果允许类型转换,则可以非常轻松地在SQL中来回转换。 如果您想直接从.NET代码插入,可能会稍有不同。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM