我想使用Execute SQL Task查询从数据库表返回varbinary数据。该查询需要UniqueIdentifier作为参数,该参数作为string存储在Package变量中。该查询的结果(varbinary数据)将存储在Byte类型的第二个变量中。

下表显示了我的局部变量列表,请注意,DocumentGuid由控制流的另一部分预先填充

| Variable Name | Qualified Name     | Scope   | Data Type | Comments                                 |
|---------------|--------------------|---------|-----------|------------------------------------------|
| DocumentGuid  | User::DocumentGuid | Package | String    | Used to store a GUID value               |
| DocumentData  | User::DocumentData | Package | Byte      | Used to hold varbinary data from a query |

当我尝试在Execute SQL Task查询中使用此代码时,如下所示:
SELECT DocData
FROM  docsRepo
WHERE DocumentGuid = ?

传递参数为
| Variable name      | Direction | Data Type | Parameter Name | Parameter Size |
|--------------------|-----------|-----------|----------------|----------------|
| User::DocumentGuid | Input     | GUID      | 0              | 100            |

和结果集
| Result Name | Variable Name      |
|-------------|--------------------|
| DocData    | User::DocumentData |

我收到以下错误:



我在这里缺少某种基本逻辑吗?以下脚本在SQL Server中可以正常工作:
SELECT DocData
FROM  docsRepo
WHERE DocumentGuid = '53A394A7-5D2B-40C0-A04D-90553E4535C3'

最佳答案

我对您的样本进行了两项更改,使它可以正常工作。

第一个是在“执行SQL任务”中将参数类型更改为字符串。我知道,这是一个向导,但是由于它是SSIS中的字符串变量,因此请保持数据类型对齐并让后端rdbms/driver处理转换。

我更改的另一件事是DocData的数据类型。您将其定义为Byte,但从未使用过,我担心它是一个完整的字节,而不是字节。无论如何,对于我创建的表,使用适用于SSIS的Object数据类型可以使其正常工作。

源查询

这是我的表,其中有一个值

IF NOT EXISTS
(
    SELECT
        *
    FROM
        sys.tables
    WHERE
        name = 'docsRepo'
)
BEGIN
    CREATE TABLE dbo.docsRepo
    (
        DocumentGuid uniqueidentifier
    ,   DocumentData varbinary(MAX)
    );

    INSERT INTO
        dbo.docsRepo
    SELECT
        '53A394A7-5D2B-40C0-A04D-90553E4535C3'
    ,   CAST('Hello world' AS varbinary(MAX));
END;

检索查询
SELECT D.DocumentData FROM dbo.docsRepo AS D WHERE D.DocumentGuid = ?;

配置了完整结果集。使用了OLE DB驱动程序。参数名称0,数据类型varchar,变量User::DocumentGuid。结果选项卡,我的结果集名称为0,变量User::DocumentData

Biml将创建一个SSIS包,以演示所有这些
<Biml xmlns="http://schemas.varigence.com/biml.xsd">
    <Connections>
        <OleDbConnection Name="localhost" ConnectionString="Provider=SQLNCLI11;Integrated Security=SSPI;Data Source=.\dev2014;Initial Catalog=tempdb" />
    </Connections>
    <Packages>
        <Package Name="SO_50028154" ConstraintMode="Linear">
            <Variables>
                <Variable Name="DocumentGuid" DataType="String">53A394A7-5D2B-40C0-A04D-90553E4535C3</Variable>
                <Variable Name="DocumentData" DataType="Object" />
            </Variables>
            <Tasks>
                <ExecuteSQL Name="SQL GenerateTable" ConnectionName="localhost">
                    <DirectInput>IF NOT EXISTS(SELECT * FROM sys.tables WHERE name='docsRepo')BEGIN CREATE TABLE dbo.docsRepo(DocumentGuid uniqueidentifier, DocumentData varbinary(max)); INSERT INTO dbo.docsRepo SELECT '53A394A7-5D2B-40C0-A04D-90553E4535C3', CAST('Hello world' AS varbinary(max)); END</DirectInput>
                </ExecuteSQL>
                <ExecuteSQL Name="SQL Retrieve data" ConnectionName="localhost" ResultSet="Full">
                    <DirectInput>SELECT D.DocumentData FROM dbo.docsRepo AS D WHERE D.DocumentGuid = ?;</DirectInput>
                    <Parameters>
                        <Parameter DataType="AnsiString" Name="0" VariableName="User.DocumentGuid" />
                    </Parameters>
                    <Results>
                        <Result Name="0" VariableName="User.DocumentData" />
                    </Results>
                </ExecuteSQL>
            </Tasks>
        </Package>
    </Packages>
</Biml>

10-01 03:43
查看更多