Преобразовать строковую переменную в GUID - PullRequest
0 голосов
/ 25 апреля 2018

Я хочу использовать запрос 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] Ошибка: не удалось выполнить запрос «SELECT DocData FROM
dbo.docsRepo ...» сследующая ошибка: «Преобразование не удалось при преобразовании из символьной строки в uniqueidentifier.».Возможные причины сбоя: проблемы с запросом, неправильно задано свойство ResultSet, неправильно заданы параметры или неправильно установлено соединение.

Мне не хватает какой-то фундаментальной логики здесь?Следующий скрипт прекрасно работает в SQL Server:

SELECT DocData 
FROM  docsRepo
WHERE DocumentGuid = '53A394A7-5D2B-40C0-A04D-90553E4535C3'

Ответы [ 4 ]

0 голосов
/ 13 августа 2018

Если вы хотите отправить свой uniqueIdentifer в качестве varchar в свою задачу «Выполнение SQL», вы можете использовать этот запрос в своей задаче «Выполнение SQL»:

DECLARE @docGuid AS UniqueIdentifier 
SET @docGuid  = CAST ( '{' + ? + '}' AS UniqueIdentifier )

SELECT DocData 
FROM  docsRepo
WHERE DocumentGuid = @docGuid

the?отправить по параметру как varchar размером 50

0 голосов
/ 25 апреля 2018

Похоже, у вас могут быть значения, хранящиеся в DocumentGuid, которые не являются действительными идентификаторами GUID, или недопустимые идентификаторы GUID, которые вы передаете в запрос

Чтобы определить, содержат ли ваша таблица недопустимые идентификаторы GUID, вы можете выполнить:

SELECT DocumentGuid
FROM  docsRepo
WHERE TRY_CAST(DocumentGuid AS UNIQUEIDENTIFIER) IS NULL
0 голосов
/ 25 апреля 2018

Я сделал два изменения в вашем образце и смог заставить его работать.

Первым было изменение типа параметра на строковое в задаче «Выполнение SQL».Я знаю, что это путеводитель, но поскольку в SSIS это строковая переменная, сохраните выравнивание типов данных и дайте бэкэнду rdbms / driver обработать преобразование.

Другой вещью, которую я изменил, был тип данных для DocData.Вы определили как Байт, но никогда не использовали это, я волнуюсь, что это один целый байт, а не байты.Во всяком случае, для таблицы, которую я создал, использование типа данных «Объект» для служб SSIS заставило его работать.

Исходный запрос

Вот моя таблица и одно значение в ней

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>
0 голосов
/ 25 апреля 2018

Вы можете попробовать явное CAST:

SELECT DocData 
FROM  docsRepo
WHERE DocumentGuid = CAST(? AS UNIQUEIDENTIFIER);
...