从NVARCHAR转换为VARBINARY时出现问题

时间:2017-06-20 11:31:59

标签: sql-server tsql sql-server-2016 varbinary

varchar转换为varbinary时,我可以将其还原。例如:

SELECT CAST('_A_Brand1[_1]A5_LP[_1].A5' AS VARBINARY)
      ,CAST('_A_Brand1[_1]A5_LP[_2].A5' AS VARBINARY);

给出了两个不同的输出:

  

0x5F415F4272616E64315B5F315D41355F4C505B5F3的 1 5D2E4135   0x5F415F4272616E64315B5F315D41355F4C505B5F3的 2 5D2E4135

但如果我使用nvarchar,我会得到相同的输出:

SELECT CAST(N'_A_Brand1[_1]A5_LP[_1].A5' AS VARBINARY)
      ,CAST(N'_A_Brand1[_1]A5_LP[_2].A5' AS VARBINARY);
  

0x5F0041005F004200720061006E00640031005B005F0031005D0041003500   0x5F0041005F004200720061006E00640031005B005F0031005D0041003500

这是一个问题,因为我以后无法执行正确的操作:

SELECT CAST(CAST('_A_Brand1[_1]A5_LP[_1].A5' AS VARBINARY) AS VARCHAR(MAX))
      ,CAST(CAST('_A_Brand1[_1]A5_LP[_2].A5' AS VARBINARY) AS VARCHAR(MAX));

SELECT CAST(CAST(N'_A_Brand1[_1]A5_LP[_1].A5' AS VARBINARY) AS NVARCHAR(MAX))
      ,CAST(CAST(N'_A_Brand1[_1]A5_LP[_2].A5' AS VARBINARY) AS NVARCHAR(MAX));

第一个是好的:

_A_Brand1[_1]A5_LP[_1].A5
_A_Brand1[_1]A5_LP[_2].A5

第二个返回相同的字符串(值丢失/削减):

_A_Brand1[_1]A5
_A_Brand1[_1]A5

1 个答案:

答案 0 :(得分:3)

默认长度SELECT CAST(CAST(N'_A_Brand1[_1]A5_LP[_1].A5' AS VARBINARY(MAX)) AS NVARCHAR(MAX)) ,CAST(CAST(N'_A_Brand1[_1]A5_LP[_2].A5' AS VARBINARY(MAX)) AS NVARCHAR(MAX)); 为30,这就是截断数据的原因。

更正后的代码:

InvokeCommandAction