SQL Server 2005 の XML 要素の値を取得するために XQuery を使用すると、NULL 値が表示されます。

文書翻訳 文書翻訳
文書番号: 914638
# をバグ: 20011171 (SQLBUDT)
すべて展開する | すべて折りたたむ

目次

現象

NULL 値を受け取ると XQuery を使用して、次の条件に該当する場合は、XML 要素の値を取得します。
  • XML 要素に関連付けられているスキーマ定義の単純コンテンツを持つ複合型として宣言されています。
  • 値は、 混在 XML 要素宣言に関連付けられているスキーマ定義の属性です。 true.
  • 使用して、 データ XML 要素の値を取得するには、[関数] をクリックします。

原因

XML 要素の複合型と単純コンテンツを持つし、混合コンテンツ宣言されて場合インライン値を XML 要素としての XML 要素の値が処理されるために発生します。そのためには、 データ 関数は、型指定された XML 要素の値を取得できません。通常、XML 要素の値は、型指定された XML 要素の子の値として処理されます。

解決方法

サービス パックの情報

この問題を解決するには、Microsoft SQL Server 2005年の最新の service pack を入手します。詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
913089 SQL Server 2005 の最新の service pack を入手する方法

回避策

この問題を回避するには、次の手順を実行します。
  1. 問題のある XML スキーマ コレクションに対して検証は、データ エントリがテーブルの列を変更する必要があります。このテーブルの列から型指定された XML 列を型指定されていない XML 列に変更しなければなりません。これを行うには、次のような Transact SQL ステートメントを使用します。
    ALTER TABLE <TableName> ALTER COLUMN <ColumnName> XML
    GO
    
  2. 既存の XML スキーマ コレクションを削除します。を除き、古い XML スキーマと同じ定義を持つ新しい XML スキーマ コレクションを作成しの値は、 混在 XML 要素の宣言の属性を設定するには false.これを行うには、次のような Transact SQL ステートメントを使用します。
    DROP XML SCHEMA COLLECTION <OldSchemaName>
    GO
    
    CREATE XML SCHEMA COLLECTION <NewSchemaName> AS N’<NewSchemaDefinition>’
    GO
    
  3. 新しい XML スキーマ コレクションに対して検証を型指定された XML 列には、テーブルの列を設定します。これを行うには、次のような Transact SQL ステートメントを使用します。
    ALTER TABLE <TableName> ALTER COLUMN <ColumnName> XML(<NewSchemaName>)
    GO
    
メモ <tablename></tablename> テーブルの名前を表します。 <columnname></columnname> XML テーブルの列の名前を表します。 <oldschemaname></oldschemaname> 古い問題のスキーマ コレクションの名前を表します。 <newschemaname></newschemaname> 新しいスキーマ コレクションの名前を表します。 <newschemadefinition></newschemadefinition> 新しいスキーマ コレクションを定義するコードを表します。

状況

マイクロソフトでは、この「対象」に記載されているマイクロソフト製品の問題として認識しています。 この問題は、最初 Microsoft SQL Server 2005 Service Pack 1 で修正済みです。

詳細

単純コンテンツを持つ複合型には、値を設定しないお勧めは、 混在 複雑な型の属性 true.World Wide Web コンソーシアム (W3C) の Web サイトで利用可能な XML スキーマ構造の仕様は、この問題もについて説明します。詳細について、「3.4.3」を参照してくださいセクションおよび「3.4.4"セクションで、次の Web サイト。
http://www.w3.org/TR/xmlschema-1/#Complex_Type_Definitions

問題の再現手順

  1. SQL Server 2005 の Management Studio を開きます。
  2. SQL Server のインスタンスに接続します。
  3. 展開 データベース 変更するデータベースをクリックします。
  4. で、 ファイル メニューのポイント 新しい、し データベース エンジン クエリ.は、 クエリ ・ エディター ウィンドウが表示されます。
  5. 次のコード例での貼り付け、 クエリ ・ エディター ウィンドウ:
    create xml schema collection myschema as N'
    <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
    	<xs:element name="ElementName" type="xs:integer" />
    		
    	<xs:complexType name="newct" mixed="true">
    		<xs:simpleContent>
    			<xs:extension base="xs:integer">
    				<xs:attribute name="bar" type="xs:integer" />
    			</xs:extension>
    		</xs:simpleContent>
    	</xs:complexType>
    </xs:schema>'
    go
    
    create table xml_test (pk int primary key identity(1,1), xmlcol xml(myschema))
    go
    
    insert xml_test values ('
    <ElementName xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="newct" bar="10">30</ElementName>')
    go
    
    insert xml_test values ('
    <ElementName>30</ElementName>')
    go
    
    select xmlcol.query('data(/ElementName)')
    from xml_test
    
出力は次のようになります。
<empty>
30
メモ この出力に<empty>何も表示されないことを示します</empty>。

ただし、出力は次のようにする必要があります。
30
30

関連情報

詳細については、 データ XQuery の機能は、次のマイクロソフト開発ネットワーク (MSDN) Web サイトを参照してください。
http://msdn2.microsoft.com/en-us/library/ms187038.aspx

プロパティ

文書番号: 914638 - 最終更新日: 2011年7月19日 - リビジョン: 4.0
キーワード:?
kbtshoot kbprb kbexpertiseadvanced kbsql2005tsql kbsql2005xml kbsql2005presp1fix kbmt KB914638 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:914638
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

フィードバック

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com