我有一些格式为 ASCII 十六进制的源数据。我需要将它放入 VARBINARY 字段中的 SQL 数据库中。我已将问题减少到最低限度,以说明我想做什么。我有一个存储过程:
CREATE PROCEDURE BinaryDemo
@BinaryData varbinary(max)
AS
BEGIN
PRINT @BinaryData;
END
我知道它“有效”,因为我可以:
DECLARE @tmp varbinary(max);
SET @tmp = CONVERT(varbinary, '1234567890abcdef', 2);
EXEC BinaryDemo @BinaryData=@tmp;
我想做的是跳过中间步骤并调用如下过程:
EXEC BinaryDemo @BinaryData=CONVERT(varbinary, '1234567890abcdef', 2);
不幸的是,SQL 抱怨语法:关键字“CONVERT”附近的语法不正确。
我知道 CONVERT 是正确的,因为我可以:
PRINT CONVERT(varbinary, '1234567890abcdef', 2);
我看到了我所期望的。由于源数据的性质和数量,第一个示例(declare/set/exec)确实是一个糟糕的选择。