OPENROWSET - 不允许从数据类型 varchar 到 varbinary(max) 的隐式转换。使用 CONVERT 函数 运行 这个查询

OPENROWSET - Implicit conversion from data type varchar to varbinary(max) is not allowed. Use the CONVERT function to run this query

您好,我正在尝试将存储过程的结果插入到名为 MyBinaryTable 的 table 中。 MyBinaryTable 包含两列:(FileId [type:int] 和 BulkColumn [type:varbinary(max)])。存储过程returns 有两个列称为FileId 和BulkColumn。从存储过程中将值插入 MyBinaryTable 时,出现以下错误:

Implicit conversion from data type varchar to varbinary(max) is not allowed. 
Use the CONVERT function to run this query.

这是我的存储过程:

CREATE PROCEDURE [dbo].[GenerateBinary] @Route VARCHAR(300), @FileId 
VARCHAR(10)
AS
Declare @sql varchar(max)
Set @sql='SELECT convert(varbinary(max),((SELECT BulkColumn FROM OPENROWSET( 
BULK ''' + @Route + ''' , SINGLE_BLOB) as Data)), 0) as ''BulkColumn'',''' + 
@FileId + ''' as ''FileId'''
Print @sql
Exec(@sql)

这是我插入值的方式:

INSERT INTO MyBinaryTable
EXEC GenerateBinary 'xyz.docx', @FileId = 254

不要养成坏习惯。您没有在插入语句中指定列列表 - 这是一个坏习惯,也是我们出错的原因。您的过程的结果集是 [varbinary(max), varchar(10)]。和你的table的结构一样吗?不。而且您还使用定义为 varchar 的 fileid 参数强制进行另一个隐式转换。因此,更改您的过程以将 fileid 定义为 int 并在插入语句中指定列:

insert dbo.MyBinaryTable(BulkColumn, FileId)
select ...;