如何将SSEST中的TIMESTAMP值转换为T-SQL中的VARCHAR?

Neo*_*Neo 12 t-sql sql-server ssms nvarchar sql-timestamp

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

以下正确显示表结果:

SELECT TOP 1 RowVersion FROM MyTable
Run Code Online (Sandbox Code Playgroud)

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

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

这会产生错误: 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)
Run Code Online (Sandbox Code Playgroud)

这导致垃圾字符: test (®

实际上,空格只是空字符并终止字符串以便运行动态SQL EXEC().

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

这只显示一个带有"test"一词的表格结果.动态SQL中"test"之后的所有内容都被截断,因为该CONVERT函数首先返回终止空字符.

显然,我想要的结果字符串是"test0x000000000000288D17AE"甚至是十进制等值,在这种情况下将是"test680335278".

任何想法将不胜感激.

Jer*_*ert 21

SELECT 'test' + CONVERT(NVARCHAR(MAX), CONVERT(BINARY(8), RowVersion), 1).诀窍是1CONVERT为风格,每文档.(通过2省略0x.)