是否有一种简单的方法可以将8个字符的字符串(char(8)
)转换为64位bigint
? (使用SQL语句)。
如何从bigint
转换回char(8)
?
例如: 'ABCDabcd'
应该变为 0x4142434461626364
('A'= 65 = 0x41,'B'= 66 = 0x42,等等)
字符串将始终满足以下条件:
转换100%准确且确定性非常重要。编码应始终提供相同的结果。
答案 0 :(得分:2)
有几种方法可以做到这一点:
-- CHAR(8) variable
DECLARE @char8 CHAR(8) = 'ABCDabcd'
-- use BINARY_CHECKSUM, should be safe with a CHAR(8)
DECLARE @checkInt64 BIGINT = BINARY_CHECKSUM(@char8)
-- use CAST(... AS BINARY(8)), should be safe with a CHAR(8)
-- note: cannot cast directly from CHAR to INT/BIGINT
DECLARE @charBinary BINARY(8) = CAST(@char8 AS BINARY(8))
DECLARE @binaryInt BIGINT = @charBinary
SELECT @char8, @checkInt64, @charBinary, @binaryInt
-- output: ABCDabcd, 1450341456, 0x4142434461626364, 4702394921898894180
-- VARBINARY/BIGINT can be casted back to the CHAR as well:
SELECT CAST(CAST(@binaryInt AS BINARY(8)) as CHAR(8)), CAST(@charBinary AS CHAR(8));
-- output: ABCDabcd, ABCDabcd
BINARY_CHECKSUM
在这个长度上适合Int64,但仅限于一种方式。
BINARY
会为您提供您想要的确切十六进制,并且也应该适合bigint,并且应该可以转换回来。