微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我试图将表中的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.)

原文地址:https://www.jb51.cc/mssql/77592.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐