17

我正在尝试将表中的 TIMESTAMP 字段转换为字符串,以便可以将其作为动态 SQL 的一部分打印或执行。SSMS 是能够做到的,所以必须有一个内置的方法来做到这一点。但是,我无法使用 T-SQL 让它工作。

以下正确显示表格结果:

SELECT TOP 1 RowVersion FROM MyTable

它显示0x00000000288D17AE. 但是,我需要将结果作为更大字符串的一部分。

DECLARE @res VARCHAR(MAX) = (SELECT TOP 1 'test' + CONVERT(BINARY(8), RowVersion) FROM MyTable)
PRINT(@res)

这会产生一个错误:The data types varchar and binary are incompatible in the add operator

DECLARE @res VARCHAR(MAX) = (SELECT TOP 1 'test' + CONVERT(VARCHAR(MAX), RowVersion) FROM MyTable)
PRINT(@res)

这会导致乱码:test (®

实际上,空格只是空字符,并终止字符串,以便使用EXEC().

DECLARE @sql VARCHAR(MAX) = 'SELECT TOP 1 ''test'' + CONVERT(VARCHAR(MAX), RowVersion) FROM MyTable'
EXEC (@sql)

这仅显示带有单词“test”的表格结果。动态 SQL 中“测试”之后的所有内容都被切断,因为该CONVERT函数首先返回终止空字符。

显然,我希望得到的字符串是“test0x00000000288D17AE”,甚至是十进制等价物,在这种情况下是“test680335278”。

任何想法将不胜感激。

4

3 回答 3

26

SELECT 'test' + CONVERT(NVARCHAR(MAX), CONVERT(BINARY(8), RowVersion), 1). 诀窍是1按照文档CONVERT的风格。(通过省略.)20x

于 2016-12-07T11:41:12.103 回答
3

如评论中所述,未记录的函数master.sys.fn_varbintohexstr会将二进制转换为字符串,以便您可以与其他一些字符串值连接:

DECLARE @binary BINARY(8)
SELECT @binary = CAST(1234567890 AS BINARY(8))

SELECT @binary AS BinaryValue, 
       LEFT(master.sys.fn_varbintohexstr(@binary),2) + UPPER(RIGHT(master.sys.fn_varbintohexstr(@binary),LEN(master.sys.fn_varbintohexstr(@binary))-2)) AS VarcharValue,
       'test' + LEFT(master.sys.fn_varbintohexstr(@binary),2) + UPPER(RIGHT(master.sys.fn_varbintohexstr(@binary),LEN(master.sys.fn_varbintohexstr(@binary))-2)) AS ConcatenatedVarcharValue

我继续拆分前两个字符并且没​​有将UPPER函数应用于它们,以准确再现二进制值时显示的格式。

结果:

/--------------------------------------------------------------------\
|     BinaryValue    |    VarcharValue    | ConcatenatedVarcharValue |
|--------------------+--------------------+--------------------------|
| 0x00000000499602D2 | 0x00000000499602D2 |  test0x00000000499602D2  |
\--------------------------------------------------------------------/
于 2016-12-07T11:24:14.860 回答
1

看看这个:

SELECT 
substring(replace(replace(replace(replace(cast(CAST(GETDATE() AS datetime2) as 
varchar(50)),'-',''),' ',''),':',''),'.',''),1,18)
于 2017-10-10T21:20:04.240 回答