sql-server – 如何将SSEST中的TIMESTAMP值转换为T-SQL中的VARCH
发布时间:2020-12-12 06:53:58 所属栏目:MsSql教程 来源:网络整理
导读:我试图将表中的TIMESTAMP字段转换为字符串,以便它可以作为动态SQL的一部分打印或执行. SSMS能够做到这一点,所以必须有一个内置的方法来做到这一点.但是,我无法使用T-SQL工作. 以下正确显示表结果: SELECT TOP 1 RowVersion FROM MyTable 它显示0x00000000288
我试图将表中的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) 这会产生错误:数据类型varchar和binary在add运算符中不兼容 DECLARE @res VARCHAR(MAX) = (SELECT TOP 1 'test' + CONVERT(VARCHAR(MAX),RowVersion) FROM MyTable) PRINT(@res) 这导致垃圾字符:test(? 实际上,空格只是空字符并终止字符串以便使用EXEC()运行动态SQL. DECLARE @sql VARCHAR(MAX) = 'SELECT TOP 1 ''test'' + CONVERT(VARCHAR(MAX),RowVersion) FROM MyTable' EXEC (@sql) 这只显示一个带有“test”一词的表格结果.动态SQL中“test”之后的所有内容都被截断,因为CONVERT函数首先返回终止空字符. 显然,我想要的结果字符串是“test0x00000000288D17AE”甚至是十进制等值,在这种情况下将是“test680335278”. 任何想法将不胜感激. 解决方法SELECT’test’CONVERT(NVARCHAR(MAX),CONVERT(BINARY(8),RowVersion),1).根据 documentation,诀窍是CONVERT为1的样式.(传递2以省略0x.)(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |