다음을 통해 공유


sql:mapped를 사용하여 XML 문서에서 스키마 요소 제외

적용 대상: SQL ServerAzure SQL Database

XSD 스키마의 모든 요소와 특성은 기본 매핑으로 인해 데이터베이스 테이블/뷰 및 열에 매핑됩니다. XSD 스키마에서 데이터베이스 테이블(뷰) 또는 열에 매핑되지 않고 XML에 표시되지 않는 요소를 만들려면 sql:mapped 주석을 지정할 수 있습니다.

sql:mapped 주석은 스키마를 수정할 수 없거나 스키마를 사용하여 다른 원본에서 XML의 유효성을 검사하지만 데이터베이스에 저장되지 않은 데이터를 포함하는 경우에 특히 유용합니다. 매핑된 sql:mapped 주석은 매핑되지 않은 요소와 특성이 XML 문서에 나타나지 않는다는 점에서 sql:is-constant와 다릅니다.

sql:mapped 주석은 부울 값(0 = false, 1 = true)을 사용합니다. 허용되는 값은 0, 1, true 및 false입니다.

예제

다음 예제를 사용하여 작업 샘플을 만들려면 특정 요구 사항을 충족해야 합니다. 자세한 내용은 SQLXML 실행 요구 사항 예제를 참조 하세요.

A. sql:mapped 주석 지정

다른 원본의 XSD 스키마가 있다고 가정합니다. 이 XSD 스키마는 ContactID, FirstName, LastNameHomeAddress 특성이 있는 Person.Contact> 요소로 구성됩니다.<

AdventureWorks 데이터베이스의 Person.Contact 테이블에 이 XSD 스키마를 매핑할 때 Employees 테이블에 직원의 집 주소가 저장되지 않으므로 HomeAddress 특성에 sql:mapped가 지정됩니다. 따라서 이 특성은 데이터베이스에 매핑되지 않으며 매핑 스키마에 대해 XPath 쿼리를 지정할 때 결과 XML 문서에 반환되지 않습니다.

스키마의 나머지 부분에 대해 기본 매핑이 발생합니다. <Person.Contact> 요소는 Person.Contact 테이블에 매핑되고 모든 특성은 Person.Contact 테이블에서 이름이 같은 열에 매핑됩니다.

<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"  
            xmlns:sql="urn:schemas-microsoft-com:mapping-schema">  
  <xsd:element name="Person.Contact">  
    <xsd:complexType>  
      <xsd:attribute name="ContactID"   type="xsd:string"/>  
      <xsd:attribute name="FirstName"    type="xsd:string" />  
      <xsd:attribute name="LastName"     type="xsd:string" />  
      <xsd:attribute name="HomeAddress" type="xsd:string"   
                     sql:mapped="false" />  
    </xsd:complexType>  
  </xsd:element>  
</xsd:schema>  
스키마에 대해 샘플 XPath 쿼리를 테스트하려면
  1. 위 스키마 코드를 복사한 후 텍스트 파일에 붙여넣습니다. 파일을 sql-mapped.xml 저장합니다.

  2. 다음 템플릿을 복사하여 텍스트 파일에 붙여넣습니다. 파일을 sql-mapped.xml 저장한 디렉터리에 sql-mappedT.xml 저장합니다.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
        <sql:xpath-query mapping-schema="sql-mapped.xml">  
            /Person.Contact[@ContactID < 10]  
        </sql:xpath-query>  
    </ROOT>  
    

    매핑 스키마(MySchema.xml)에 대해 지정된 디렉터리 경로는 템플릿이 저장된 디렉터리에 상대적입니다. 절대 경로도 지정할 수 있습니다. 예를 들면 다음과 같습니다.

    mapping-schema="C:\MyDir\sql-mapped.xml"  
    
  3. SQLXML 4.0 테스트 스크립트(Sqlxml4test.vbs)를 만들고 사용하여 템플릿을 실행합니다.

    자세한 내용은 ADO를 사용하여 SQLXML 쿼리를 실행합니다.

결과 집합은 다음과 같습니다.

<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
  <Person.Contact ContactID="1" FirstName="Gustavo" LastName="Achong" />   
  <Person.Contact ContactID="2" FirstName="Catherine" LastName="Abel" />   
  <Person.Contact ContactID="3" FirstName="Kim" LastName="Abercrombie" />   
  <Person.Contact ContactID="4" FirstName="Humberto" LastName="Acevedo" />   
  <Person.Contact ContactID="5" FirstName="Pilar" LastName="Ackerman" />   
  <Person.Contact ContactID="6" FirstName="Frances" LastName="Adams" />   
  <Person.Contact ContactID="7" FirstName="Margaret" LastName="Smith" />   
  <Person.Contact ContactID="8" FirstName="Carla" LastName="Adams" />   
  <Person.Contact ContactID="9" FirstName="Jay" LastName="Adams" />   
</ROOT>  

ContactID, FirstName 및 LastName이 있지만 HomeAddress는 매핑 스키마가 sql:mapped 특성에 대해 0을 지정했기 때문이 아닙니다.

참고 항목

테이블 및 열에 XSD 요소 및 특성의 기본 매핑(SQLXML 4.0)