我正在尝试将表中的 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”。
任何想法将不胜感激。