3

テーブル DOCUMENTS があります:

DOCUMENTS
____________________
DOCUMENTID   int
USERID       int
CONTENT      text

次の XML を SQL Server データベースの CONTENT という名前の TEXT 列に格納しています

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<IDMSDocument>
    <DocumentContent>
        <Attribute Name="Number" GUID="{FFFFFFFF-0000-0000-0000-000000000001}">
            <IDMSType>3060</IDMSType>
            <Value Type="Integer">
                <Value>122</Value>
            </Value>
        </Attribute>
        <Attribute Name="Date" GUID="{FFFFFFFF-0000-0000-0000-000000000002}">
            <IDMSType>3061</IDMSType>
            <Value Type="DateTime">
                <Date>10-09-2014</Date>
            </Value>
        </Attribute>
        <Attribute Name="Публикуване" GUID="{CA646F55-5229-4FC5-AA27-494B25023F4E}">
            <IDMSType>3062</IDMSType>
            <Value Type="String">
                <Value>Да</Value>
            </Value>
        </Attribute>
        <Attribute Name="Дата" GUID="{AC0465B0-4FB4-49E2-B4FA-70901068FD9B}">
            <IDMSType>3063</IDMSType>
            <Value Type="DateTime">
                <Date>01-10-2014</Date>
            </Value>
        </Attribute>
        <Attribute Name="Предмет на поръчка" GUID="{04A4EC72-6F33-461F-98DD-D8D271997788}">
            <IDMSType>3065</IDMSType>
            <Value Type="String">
                <Value>Избор на консултанти</Value>
            </Value>
        </Attribute>
    </DocumentContent>
</IDMSDocument>

テーブルから単一の行でディングル XML 属性をクエリする方法を見つけました。

DECLARE @strContent NVARCHAR(MAX);
DECLARE @xmlContent XML;
SET @strContent = (select content from DOCUMENTS where DocumentID=24);
SET @xmlContent = CAST(REPLACE(CAST(@strContent AS NVARCHAR(MAX)),'utf-8','utf-16') AS XML) 
SELECT @xmlContent.query('/IDMSDocument/DocumentContent/Attribute[5]/Value/Value') 
where @xmlContent.value('(/IDMSDocument/DocumentContent/Attribute[5]/Value/Value)[1]', 'nvarchar(max)') like '%search%'

「XMLの5番目の属性に値「検索」があるテーブルのすべての行を選択する」のようなクエリを作成する必要があります

私にとって一般的な問題は、列の型が XML ではないことですが、内部に xml が格納されたテキスト列があります。キャスト、クエリ、値を直接サーバーから返すと、XML列でのみ使用できます。

誰かがこれを行う方法を提案してくれたら、とても感謝しています!

ありがとう!

仮面

4

1 に答える 1

3

SQL Server では、インライン XML 変換に関数を適用することはできません。つまり、 no CAST(...).query()、CTE を使用して変換を処理します。

;WITH cte AS (
  SELECT DocumentID, UserID, CAST(Content AS XML) AS XMLContent
  FROM Documents
)

SELECT XMLContent.query('/IDMSDocument/DocumentContent/Attribute[5]/Value/Value') 
FROM cte
WHERE XMLContent.value('(/IDMSDocument/DocumentContent/Attribute[5]/Value/Value)[1]', 'nvarchar(max)') like '%search%'

ただし、Content列に Unicode (ロシア語?) 文字が表示されていました。utf-16XML およびntext列タイプで使用する方がよい場合があります。

textntext途中です . これが新しいコードの場合は、nvarchar(max)

于 2014-10-16T00:04:47.113 に答える