试图从 c# 字符串转换为 SQL 二进制文件
Posted
技术标签:
【中文标题】试图从 c# 字符串转换为 SQL 二进制文件【英文标题】:Trying to convert from c# string to SQL binary 【发布时间】:2015-06-06 11:43:40 【问题描述】:我正在构建一个 c# 应用程序,它需要使用我们的 SQL Server 数据库中的二进制 (16) 唯一标识符。目前,应用程序将这些存储为字符串。
我希望能够将唯一 id 作为字符串传递给 varchar 参数并在 sql 语句中进行转换,但我得到了一些奇怪的结果。
CONVERT(binary(16), '0x6EC5CAE61DF38840B8EFEC2D5A158B3A', 1)
--desired: 0x6EC5CAE61DF38840B8EFEC2D5A158B3A
--actual: 0x307836454335434145363144463338383430423845464543324435413135
有没有办法以这种方式转换它?这是我在各个地方找到的解决方案,但我无法让它发挥作用。我还尝试了其他一些建议:
CONVERT(binary(16), '0x6EC5CAE61DF38840B8EFEC2D5A158B3A', [1-3])
CONVERT(varbinary(16), '0x6EC5CAE61DF38840B8EFEC2D5A158B3A', [1-3])
CONVERT(binary(16), '6EC5CAE61DF38840B8EFEC2D5A158B3A', [1-3])
CONVERT(varbinary(16), '6EC5CAE61DF38840B8EFEC2D5A158B3A', [1-3])
CAST('' AS XML).value('sql:variable("@Variable")', 'binary(16)')
无济于事。
如果这样更可取,我可以在我的应用程序中以不同的方式存储它们,但我不确定要使用什么数据类型?据我所知,c# 中没有二进制等价物?
提前致谢。
【问题讨论】:
已经是二进制了。您不需要转换它,也不需要它周围的引号。只需使用二进制类型参数而不是 varchar。 我认为吉姆的意思是你可以做这样的事情declare @id binary(16) = 0x6EC5CAE61DF38840B8EFEC2D5A158B3A
。注意二进制数据周围没有引号。
是的,达纳说的 :)
你能展示产生0x307...
值的实际代码吗?我无法重现该问题。
我在 c# 中使用了一个 Parameter 对象,它不允许我将字符串放入 dbtype="binary" 的参数中。我的总体问题是将 c# 字符串放入 SQL 中的二进制(16)变量中。
【参考方案1】:
我无法让 uniqueidentifier 示例正常工作,但同事指出的这个解决方案似乎有效。
DECLARE @id varchar(max)
DECLARE @idNew binary(16)
SET @id = '0x6EC5CAE61DF38840B8EFEC2D5A158B3A'
SET @idNew = cast('' as xml).value('xs:hexBinary(substring(sql:variable("@id"), 3) )', 'varbinary(max)')
select @idNew
我完全理解 xQuery 的工作原理,但这似乎可以正确转换它。
有了这个,我可以将 c# 字符串传递给@id 变量、转换并在 sql 语句中使用 @idNew。
编辑:
信用/更多信息:
http://blogs.msdn.com/b/sqltips/archive/2008/07/02/converting-from-hex-string-to-varbinary-and-vice-versa.aspx
【讨论】:
【参考方案2】:如果这是 SQL 唯一标识符,则 C# 等效项是 GUID。
【讨论】:
以上是关于试图从 c# 字符串转换为 SQL 二进制文件的主要内容,如果未能解决你的问题,请参考以下文章