如何像 SSMS 那样在 T-SQL 中将 TIMESTAMP 值转换为 VARCHAR?
How to convert TIMESTAMP values to VARCHAR in T-SQL as SSMS does?
我正在尝试将 table 中的 TIMESTAMP 字段转换为字符串,以便它可以作为动态 SQL 的一部分打印或执行。 SSMS 能够做到这一点,因此必须有一个内置的方法来做到这一点。但是,我无法使用 T-SQL.
让它工作
以下正确显示 table 结果:
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 (®
事实上,空格只是空字符,为了 运行 动态 SQL 使用 EXEC()
.
的目的终止字符串
DECLARE @sql VARCHAR(MAX) = 'SELECT TOP 1 ''test'' + CONVERT(VARCHAR(MAX), RowVersion) FROM MyTable'
EXEC (@sql)
这只会显示 table 结果,其中包含单词 "test"。动态 SQL 中 "test" 之后的所有内容都被截断,因为 CONVERT
函数 returns 首先终止空字符。
显然,我想要的结果字符串是 "test0x00000000288D17AE" 或什至十进制等效值,在本例中为 "test680335278".
如有任何想法,我们将不胜感激。
如评论中所述,未记录的函数 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 |
\--------------------------------------------------------------------/
SELECT 'test' + CONVERT(NVARCHAR(MAX), CONVERT(BINARY(8), RowVersion), 1)
。诀窍是 1
到 CONVERT
作为样式,根据 documentation。 (传递 2
以省略 0x
。)
看看这个:
SELECT
substring(replace(replace(replace(replace(cast(CAST(GETDATE() AS datetime2) as
varchar(50)),'-',''),' ',''),':',''),'.',''),1,18)
我正在尝试将 table 中的 TIMESTAMP 字段转换为字符串,以便它可以作为动态 SQL 的一部分打印或执行。 SSMS 能够做到这一点,因此必须有一个内置的方法来做到这一点。但是,我无法使用 T-SQL.
让它工作以下正确显示 table 结果:
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 (®
事实上,空格只是空字符,为了 运行 动态 SQL 使用 EXEC()
.
DECLARE @sql VARCHAR(MAX) = 'SELECT TOP 1 ''test'' + CONVERT(VARCHAR(MAX), RowVersion) FROM MyTable'
EXEC (@sql)
这只会显示 table 结果,其中包含单词 "test"。动态 SQL 中 "test" 之后的所有内容都被截断,因为 CONVERT
函数 returns 首先终止空字符。
显然,我想要的结果字符串是 "test0x00000000288D17AE" 或什至十进制等效值,在本例中为 "test680335278".
如有任何想法,我们将不胜感激。
如评论中所述,未记录的函数 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 |
\--------------------------------------------------------------------/
SELECT 'test' + CONVERT(NVARCHAR(MAX), CONVERT(BINARY(8), RowVersion), 1)
。诀窍是 1
到 CONVERT
作为样式,根据 documentation。 (传递 2
以省略 0x
。)
看看这个:
SELECT
substring(replace(replace(replace(replace(cast(CAST(GETDATE() AS datetime2) as
varchar(50)),'-',''),' ',''),':',''),'.',''),1,18)