Présentation de la contrainte d'attribution de particule unique

Dans XSD, les modèles de contenu complexe sont soumis à la règle de la contrainte d'attribution de particule unique. Cette règle requiert que chaque élément d'un document d'instance corresponde sans ambiguïté à exactement une particule <xsd:element> ou <xsd:any> dans le modèle de contenu de son parent. Tout schéma qui contient un type avec un modèle de contenu potentiellement ambigu est rejeté.

Les causes d'ambiguïté les plus courantes sont les caractères génériques et les particules <xsd:any> ayant des plages d'occurrences variables, telles que minOccurs < maxOccurs. Par exemple, le modèle de contenu suivant est ambigu car un élément <e1> peut correspondre à l'élément <xsd:element> ou à l'élément <xsd:any> .

<xsd:element name="root">
    <xsd:complexType>
        <xsd:choice>
            <xsd:element name="e1"/>
            <xsd:any namespace="##any"/>
        </xsd:choice>
    </xsd:complexType>
</xsd:element>

Le modèle de contenu suivant est également ambigu :

<xsd:element name="root">
    <xsd:complexType>
        <xsd:sequence>
            <xsd:element name="e1" maxOccurs="2"/>
            <xsd:element name="e2" minOccurs="0"/>
            <xsd:element name="e1"/>
        </xsd:sequence>
    </xsd:complexType>
</xsd:element>

Bien qu'un document tel que <root><e1/><e2/><e1/></root> puisse être validé sans ambiguïté, un document tel que <root><e1/><e1/></root> ne le peut pas car il est difficile de déterminer à quel élément <xsd:element> correspond le second élément <e1/>. Même si certains documents peuvent être validés sans ambiguïté, le schéma est rejeté en raison d'une ambiguïté potentielle.

Pour qu'un modèle de contenu soit valide, il doit être possible de valider n'importe quelle instance sans ambiguïté, indépendamment des éléments à venir. Imaginons par exemple le modèle de contenu suivant :

<xsd:element name="root">
    <xsd:complexType>
        <xsd:choice>
           <xsd:sequence>
               <xsd:element name="e1"/>
               <xsd:element name="e2"/>
           </xsd:sequence>
           <xsd:sequence>
               <xsd:element name="e1"/>
               <xsd:element name="e3"/>
           </xsd:sequence>
       </xsd:choice>
    </xsd:complexType>
</xsd:element>

Pour un document tel que <root><e1/><e3/></root>, la séquence <e1/><e3/> correspond sans ambiguïté à la deuxième séquence <xsd:sequence>. Toutefois, étant donné que l'élément <xsd:element> auquel correspond <e1/> ne peut pas être déterminé sans tenir compte de <e3/>, le modèle de contenu enfreint la règle de la contrainte d'attribution de particule unique.

Sources d'informations complémentaires

Le document suivant est publié par le World Wide Web Consortium (W3C) et contient la description technique de la contrainte d'attribution de particule unique :

« XML Schema Part 1: Structures Second Edition, W3C Proposed Edited Recommendation » :

  • Section 3.8.6 : Constraints on Model Group Schema Components
  • Appendix H : Analysis of the Unique Particle Attribution Constraint (non-normative)

Ce document est disponible à l'adresse http://www.w3.org/TR/xmlschema-1, qui propose également un lien (« translations ») vers la traduction française d'une version antérieure.

Voir aussi

Référence

Gestion des collections de schémas XML sur le serveur

Aide et Informations

Assistance sur SQL Server 2005