как конвертировать xml-вывод из TSQL-запроса в вывод varchar - PullRequest
5 голосов
/ 22 февраля 2011

Я пытаюсь сгенерировать

SELECT DISTINCT
        P.DOMAIN_ID,
        P.SOURCE_SYSTEM_ID
FROM    EDW.dbo.DOMAIN_VALUE AS P
WHERE   P.ID = 4
        AND CURRENT_FLAG = 'Y'
EXCEPT
( SELECT    F.DOMAIN_ID,
            F.SOURCE_SYSTEM_ID
  FROM      EDW.dbo.DOMAIN AS F
  WHERE     F.ID = 4
            AND F.CURRENT_FLAG = 'Y'
)
FOR     XML PATH('DOMAIN'),
            ROOT('DOMAIN_VALUE')  

Выходное значение в XML на вкладке Результат как

<REFERENCE_DOMAIN_VALUE>
   <REFERENCE_DOMAIN>
       <REFERENCE_DOMAIN_ID>10799</REFERENCE_DOMAIN_ID>
       <REFERENCE_SOURCE_SYSTEM_ID>7452-001</REFERENCE_SOURCE_SYSTEM_ID>
   </REFERENCE_DOMAIN>
</REFERENCE_DOMAIN_VALUE>

Теперь мне нужно преобразовать этот XML в varchar (max), но результат должен быть таким же.

1 Ответ

6 голосов
/ 22 февраля 2011

Просто вложите его в скалярное значение и преобразуйте его.Хитрость в том, что FOR XML in a subquery и EXCEPT сверху не смешиваются, поэтому сначала запросите часть EXCEPT.

SELECT CONVERT(varchar(max), (
    SELECT * FROM (
        SELECT DISTINCT P.DOMAIN_ID, P.SOURCE_SYSTEM_ID
        FROM EDW.dbo.DOMAIN_VALUE AS P
        WHERE P.ID = 4 AND CURRENT_FLAG = 'Y'
        EXCEPT (
        SELECT F.DOMAIN_ID, F.SOURCE_SYSTEM_ID
        FROM EDW.dbo.DOMAIN AS F
        WHERE F.ID = 4 AND F.CURRENT_FLAG = 'Y' )
    ) I
    FOR XML PATH('DOMAIN'), ROOT('DOMAIN_VALUE')
))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...