Introdução Ao XML Schema
Introdução Ao XML Schema
XML Schema uma alternativa ao DTD baseada em XML. Um esquema XML descreve a estrutura de um documento XML. A linguagem XML Schema tambm chamada de XML Schema Definition (XSD).
Uma das grandes vantagens de XML Schemas o suporte a tipos de dados: mais fcil descrever contedo de documentos permissveis mais fcil validar os dados mais fcil trabalhar com dados de um banco de dados mais fcil definir restries aos dados mais fcil definir padres/formatos de dados mais fcil converter dados entre diferentes tipos
<date type="date">2004-03-11</date> assegura um entendimento mtuo do contedo porque o o tipo de dado XML requer o formato YYYY-MM-DD.
deve ter um elemento raiz nico todas tags abertas precisam ser fechadas tags XML so sensveis caixa alta/baixa todo elemento deve ser fechado todo elemento tem que ser propriamente aninhado todos valores de atributos precisam estar entre aspas entidades XML devem ser usadas para caracteres especiais
Mesmo se os documentos so bem formados eles podem conter erros, e estes erros podem ter conseqncias srias. Imagine essa situao: voc compra 5 tonners de impressoras laser, ao invs de 5 impressoras laser. Com XML Schemas, a maioria destes erros podem ser detectados pelo seu software de validao.
XSD How To
Documentos XML podem referenciar um DTD ou um XML Schema.
<?xml version="1.0"> <note> <to>Tove</to> <from>Jani</from> <heading>Reminder<heading> <body>Don't forget me this weekend!</body> </note>
Um DTD simples
Este um arquivo DTD chamado "note.dtd" que define os elementos do documento XML acima ("note.xml"):
<!ELEMENT note (to, from, heading, body)> <!ELEMENT to (#PCDATA)> <!ELEMENT from (#PCDATA)> <!ELEMENT heading (#PCDATA)> <!ELEMENT body (#PCDATA)> A linha 1 define que o elemento note possui 4 elementos: "to, from, heading, body". Linhas 2 a 5 o elemento to como sendo do tipo "#PCDATA", o elemento from como "#PCDATA", e assim por diante...
<xs:element name="note"> <xs:complexType> <xs:sequence> <xs:element name="to" type="xs:string"/> <xs:element name="from" type="xs:string"/> <xs:element name="heading" type="xs:string"/> <xs:element name="body" type="xs:string"/> </xs:sequence> </xs:complexType> </xs:element>
</xs:schema> O elemento note dito um tipo complexo porque contm outros elementos. Os outros elementos so ditos tipos simples porque no contm outros elementos. Voc vai aprender mais sobre tipos simples e complexo nos prximos captulos.
<?xml version="1.0"?>
<?xml version="1.0"?>
O elemento <schema>
O elemento <schema> o elemento raiz de todo XML Schema:
<?xml version="1.0"?>
<xs:schema>
... ...
</xs:schema> O elemento <schema> pode conter alguns atributos. Uma declarao de Schema geralmente parece com isto:
<?xml version="1.0"?>
...
...
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" indica que os elementos e tipos de dados usados no esquema (schema, element, complexType, sequence, string, boolean, etc.) vm do namespace "http://www.w3.org/2001/XMLSchema". Ele tambm especifica que os elementos e tipos de dados que vm de "http://www.w3.org/2001/XMLSchema" devem ser prefixados com xs: !! Este fragmento:
targetNamespace="http://www.w3schools.com" indica que os elementos definidos por este esquema (note, to, from, heading, body) vm do namespace "http://www.w3schools.com" . Este fragmento:
elementFormDefault="qualified"> indica que todo elemento usado por uma instncia de documento XML que foi declarado neste esquema deve ser qualificado pelo namespace.
<?xml version="1.0"?>
xmlns="http://www.w3schools.com" especifica a declarao de namespace padro. Esta declarao diz ao validador de esquema que os elementos usados neste documento XML so declarados no namespace "http://www.w3schools.com". Uma vez que voc tem uma instncia XML Schema do namespace disponvel:
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" voc pode usar o atributo schemaLocation. Este atributo tem dois valores. O primeiro o namespace usado. O segundo a localizao do esquema XML para se usado pelo namespace:
xsi:schemaLocation="http://www.w3schools.com note.xsd">
<xs:element name="xxx" type="yyy"/> onde xxx o nome do elemento e yyy o tipo de dado do elemento. Aqui est alguns elementos XML:
<lastname>Refsnes</lastname> <age>34</age>
<xs:element name="color" type="xs:string" default="red"/> Um valor fixo tambm atribudo automaticamente ao elemento. Voc no pode especificar outro valor. No exemplo a seguir, o valor fixo "red":
Atributos XSD
Todos atributos so declarados como tipos simples. Apenas elementos complexos tem atributos!
O que um atributo?
Elementos simples no podem ter atributos. Se um elemento tem atributos, ele considerado do tipo complexo. Mas atributos so declarados como tipos simples. Isso significa que um elemento com atributos sempre tem uma definio do tipo complexo.
<xs:attribute name="xxx" type="yyy"/> onde xxx o nome do atributo e yyy o tipo de dado do atributo. Aqui est um elemento XML com um atributo:
<xs:attribute name="lang" type="xs:string" default="EN"> Um valor fixo atribudo automaticamente ao atributo. Voc no pode especificar outro valor. No exemplo seguinte, o valor fixo "EN":
Restries de contedo
Quando um elemento ou um atributo XML tem um tipo definido, isto cria uma restrio ao contedo dele. Se um elemento XML do tipo "xs:date" e contm um string como "Hello Mother", o elemento no vai ser validado. Mas, h mais... com XML Schemas, voc pode adicionar suas prprias restries aos seus elementos e atributos XML. Estas restries so chamadas facets. Voc pode ler mais sobre facets no prximo captulo.
Restries/facets XSD
Restries so usadas para controlar os valores aceitos para elementos e atributos XML. Restries em elementos XML so chamados facets.
Restries em valores
Este exemplo define um elemento chamado "age" com um restrio. O valor de age no pode ser menor que 0 ou maior que 100:
<xs:element name="age">
</xs:element>
<xs:element name="car">
<xs:simpleType> <xs:restriction base="xs:string"> <xs:enumeration value-"Audi"/> <xs:enumeration value="Golf"/> <xs:enumeration value="BMW"/> </xs:restriction>
</xs:simpleType>
</xs:element> O elemento "carro" um tipo simples com restrio. Os valores aceitveis so: Audi, Golf, BMW. O exemplo acima tambm poderia ser escrito assim:
<xs:simpleType name="carType"> <xs:restriction base="xs:string"> <xs:enumeration value="Audi"/> <xs:enumeration value="Golf"/> <xs:enumeration value="BMW"/> </xs:restriction> <xs:simpleType> Nota: Neste caso o tipo "carType" pode ser usado por outros elementos, porque ele no parte do elemento "car".
<xs:element name="letter">
</xs:element> O elemento "letter" do tipo simples com uma restrio. O nico valor aceitvel UMA das letras MINSCULAS de a at z. O prximo exemplo define um elemento chamado "initials":
<xs:element name="initials">
<xs:element> O elemento "initials" simples com um restrio. O nico valor aceitvel so TRS letras MAiSCULAS de a at z. Este exemplo tambm define um elemento chamado "initials":
<xs:element name="initials">
<xs:element> O elemento "initials" do tipo simples com restrio. O nico valor aceitvel so TRS letras MINSCULAS ou MAISCULAS de a at z. Este exemplo define um elemento chamado "choice":
<xs:element name="choice">
</xs:element> O elemento "choice" um tipo simples com restrio. O nico valor aceitvel UMA das seguintes letras: x, y, OU z. O prximo exemplo define um elemento chamado "prodid":
<xs:element name="prodid">
</xs:element> O elemento "prodid" um tipo simples com restrio. O nico valor aceitvel so CINCO dgitos em seqncia, e cada dgito deve estar entre 0 e 9.
<xs:element name="letter">
</xs:element> O elemento "letter" um tipo simples com restrio. O valor aceitvel zero ou mais ocorrncias de letras minsculas de a at z. Este exemplo tambm define um elemento chamado "letter":
<xs:element name="letter">
</xs:element>
O elemento "letter" um tipo simples com um restrio. O valor aceitvel uma ou mais ocorrncias de um letra minscula seguida de uma letra maiscula de a at z. Este exemplo define um elemento chamado "gender":
<xs:element name="gender">
</xs:element> O elemento "gender" um tipo simples com uma restrio. O nico valor aceitvel male OU female. Este exemplo define um elemento chamado "password":
<xs:element name="password">
<xs:element> O elemento "password" um tipo simples com um restrio. Deve haver exatamente oito caracteres e estes caracteres devem ser letras minsculas ou maisculas de a at x, ou um nmero de 0 a 9.
<xs:element name="adress">
</xs:element> O elemento "adress" um tipo simples com um restrio. A restrio whiteSpace definida como "preserve", qu significa que o processador XML NO VAI remover nenhum caractere vazio. Este exemplo tambm define um elemento chamado "address":
<xs:element name="address">
</xs:element> Este elemento "address" um tipo simples com um restrio. A restrio whiteSpace definida como "replace", que significa que o processador XML VAI SUBSTITUIR todos caracteres vazios (quebras de linha, tabs, espaos) com espaos. Este exemplo tambm define um elemento chamado "address":
<xs:element name="address">
</xs:element> Este elemento "address" um tipo simples com uma restrio. A restrio whiteSpace definida como "collapse", que significa que o processador XML VAI REMOVER todos caracteres vazios (quebras de linha, tabs, espaos so substitudos com espaos, espaos iniciais e finais so removidos, espaos mltiplos so reduzidos a um).
Restries de comprimento
Para limitar o comprimento de um elemento, ns usamos as restries de comprimento, maxLength e minLength. Este exemplo define um elemento chamado "password":
<xs:element name="password">
</xs:element> O elemento "password" um tipo simples com uma restrio. O valor deve ter exatamente oito caracteres. Este exemplo define outro elemento chamado "password":
<xs:element name="password">
</xs:element> Este elemento "password" um tipo simples com uma restrio. O valor deve ter no mnimo cinco e no mximo oito caracteres.
Especifica o valor mximo para valores numricos (o valor deve ser menor ou igual a este valor) Especifica o nmero mximo de caracteres ou itens permitidos. Deve ser igual ou maior que zero Especifica o valor mnimo para valores numricos (o valor deve ser maior que este valor) Especifica o valor mnimo para valores numricos (o valor deve ser maior ou igual a este valor) Especifica o nmero mnimo de caracteres ou itens permitidos. Deve ser igual ou maior que zero Define a seqncia exata de caracteres permitidos Especifica o nmero exato de digitos permitidos. Deve ser maior que zero Especifica como caracteres vazios (tabs, espaos e retornos de carro) so tratados
<product pid="1245"/> Um elemento XML complexo, "employee", que contm apenas outros elementos:
<employee> <firstname>John</firstname> <lastname>Smith</lastname> </employee> Um elemento XML complexo, "food", que contm apenas texto:
<food type="dessert">Ice cream</food> Um elemento XML complexo, "description", que contm outros elementos e texto:
<employee> <firstname>John</firstname> <lastname>Smith</lastname> </employee> Ns podemos definir um elemento complexo em um XML Schema de diferente maneiras: 1. O elemento "employee" pode ser declarado diretamente, nomeando o elemento:
<xs:element name="employee"> <xs:complexType> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> <xs:sequence> </xs:complexType> </xs:element> Se voc usar o mtodo descrito acima, apenas o elemento "employee" pode usar o tipo complexo definido. Note que os elementos filhos, "firstname" e "lastname", so envolvidos pelo indicador <sequence>. Isto significa que os elementos filhos devem aparecer na mesma ordem da declarao: "firstname" primeiro e "lastname" depois. Voc vai aprender sobre indicadores no captulo Indicadores XSD; 2. O elemento "employee" pode ter um atributo tipo que faz referncia ao nome do tipo complexo que deve ser usado:
<xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string/"> </xs:sequence> </xs:complexType> Se voc usar o mtodo descrito acima, vrios elementos podem fazer referncia ao mesmo tipo complexo, assim:
<xs:complexType name="personinfo"> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> </xs:sequence> </xs:complexType> Voc tambm pode basear um elemento do tipo complexo em um tipo complexo existente e adicionar alguns elementos, assim:
<xs:complexType name="personinfo"> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="personinfo" type="xs:string"/> </xs:sequence> </xs:complexType>
<xs:complexType name="fullpersoninfo"> <xs:complexContent> <xs:extension base="personinfo"> <xs:sequence> <xs:element name="address" type="xs:string"/> <xs:element name="city" type="xs:string"/> <xs:element name="country" type="xs:string"/> </xs:sequence> </xs:extension> </xs:complexContent>
<xs:complexType>
<product prodid="1345"/> O elemento "product" acima no tem contedo. Para definir um tipo sem contedo, ns devemos definir um tipo que permita apenas elementos em seu contedo, mas ns no declaramos nenhum elemento realmente, assim:
<xs:element name="product"> <xs:complexType> <xs:complexContent> <xs:restriction base="xs:integer"> <xs:attribute name="prodid" type="xs:positiveInteger"/> </xs:restriction> </xs:complexContent> </xs:complexType> </xs:element> No exemplo acima, ns definimos um complexType tento complexContent, i.e. apenas elementos. O elemento complexContent diz que queremos restringir ou extender o modelo de contedo de um tipo complexo, e a restrio de inteiros declara um atributo mas no cria nenhum elemento. Entretanto, possvel declarar o elemento product de forma mais compacta, assim:
<xs:element name="product"> <xs:complexType> <xs:attribute name="prodid" type="xs:positiveInteger"/> </xs:complexType> </xs:element> Ou voc pode dar um nome ao complexType, e fazer o elemento "product" ter um tipo que faz referncia ao nome do complexType (se voc usar este mtodo, vrios elementos podem referenciar o mesmo tipo complexo):
<person> <firstname>John</firstname> <lastname>Smith</lastname> </person> Voc pode definir o elemento "person" em um esquema, assim:
<xs:element name="person"> <xs:complexType> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> </xs:sequence> </xs:complexType> </xs:element> Note a tag <xs:sequence>. Isto significa que os elementos definidos ("firstname" e "lastname") devem aparecer nesta ordem dentro do elemento "person". Ou voc pode dar um nome ao complexType, e um atributo type ao elemento "person" que faz referncia a ele (se voc usar este mtodo, vrios elementos podem referenciar o mesmo tipo complexo).
<xs:complexType name="persontype"> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> </xs:sequence>
</xs:complexType>
<xs:element name="somename"> <xs:complexType> <xs:simpleContent> <xs:extension base="basetype"> .... .... </xs:extension> </xs:simpleContent> </xs:complexType> </xs:element>
OU
<xs:element name="somename"> <xs:complexType> <xs:simpleContent> <xs:restriction base="basetype"> .... .... </xs:restriction> </xs:simpleContent> </xs:complexType> </xs:element> Dica: Use o elemento extension para expandir o tipo simples base de um elemento, e o elemento restriction para limit-lo. Aqui est um exemplo de um elemento XML, "shoesize", que contm apenas texto: <shoesize country="france">35</shoesize> O exemplo a seguir declara um complexType, "shoesize". O contedo definido como tipo de dado integer e o elemento "shoesize" tambm contm um atributo chamado "country":
<xs:element name="shoesize"> <xs:complexType> <xs:simpleContent> <xs:extension base="xs:integer": <xs:attribute name="country" type="xs:string"/> </xs:extension> </xs:simpleContent> </xs:complexType> </xs:element> Ns tambm poderamos definir um nome para o complexType, e especificar um atributo type ao elemento "shoesize" que faz referncia ao nome do complexType (se voc usar este mtodo, vrios elementos podem referenciar o mesmo tipo complexo):
<xs:complexType name="shoetype"> <xs:simpleContent> <xs:extension base="xs:integer"> <xs:attribute name="country" type="xs:string"/> </xs:extension> </xs:simpleContent> </xs:complexType>
<letter> Dear Mr.<name>John Smith</nam> Your order <orderid>1032</orderid> wil be shipped on <shipdate>2001-07-13</shipdate>. </letter> Note o texto que aparece entre os elementos. "name", "orderid", e "shipdate" so todos filhos de "letter". O seguinte esquema declara o elemento "letter":
<xs:element name="letter">
<xs:complexType mixed="true"> <xs:sequence> <xs:element name="name" type="xs:string"/> <xs:element name="orderid" type="xs:positiveInteger"/> <xs:element name="shipdate" type="xs:date"/> </xs:sequence> </xs:complexType> <xs:element> Nota: Para permitir que caracteres apaream entre os elementos filhos de "letter", o atributo mixed deve ser definido como "true". A tag <xs:sequence> significa que os elementos definidos (name, orderid e shipdate) devem parecer nesta ordem no elemento "letter". Ns tambm poderamos dar um nome ao elemento complexType, e definir o atributo type de "letter" como uma referncia a ele (se voc usar este mtodo, vrios elementos podem fazer referncia ao mesmo complexType):
<xs:complexType name="lettertype" mixed="true"> <xs:sequence> <xs:element name="name" type="xs:string"/> <xs:element name="orderid" type="xs:positiveInteger"/> <xs:element name="shipdate" type="xs:date"/> </xs:sequence> </xs:complexType>
Indicadores
Ns temos sete tipos de indicadores: Indicadores de ordem: All Choice Sequence
Indicadores de ordem
Indicadores de ordem so usados para definir a ordem em que os elementos ocorrem.
Indicador All
O indicador <all> especifica por padro que os elementos filhos podem aparecer em qualquer ordem e que cada um deve ocorrer, e apenas uma vez:
<xs:element name="person"> <xs:complexType> <xs:all> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> </xs:all> </xs:complexType> </xs:element> Nota: Usando o indicador <all> voc pode especificar o indicador <minOccurs> em 0 ou 1 e <maxOccurs> s pode ser 1 (<minOccurs> e <maxOccurs> so descritos adiante).
Indicador choice
O indicador <choice> especifica que um elemento filho ou outro pode ocorrer:
<xs:element name="person"> <xs:complexType> <xs:choice> <xs:element name="employee" type="employee"/> <xs:element name="member" type="member"/> </xs:choice> </xs:complexType> </xs:element>
Indicador sequence
O indicador <sequence> especifica que os elementos filhos devem aparecer em uma ordem especfica:
<xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> </xs:sequence> </xs:complexType> </xs:element>
Indicadores de ocorrncia
Indicadores de ocorrncia so usados para indicar com que freqncia um elemento pode ocorrer. Nota: Para todos indicadores "Order" e "Group" (any, all, choice, sequence, group, name, e group reference) o valor padro de maxOccurs e minOccurs 1!!!
Indicador maxOccurs
O indicador <maxOccurs> especifica o nmero mximo de vezes que um elemento pode ocorrer:
<xs:element name="person"> <xs:complexType> <xs:sequence> <xs:element name="full_name" type="xs:string"/> <xs:element name="child_name" name="child_name" type="xs:string" maxOccurs="10"/> </xs:sequence> </xs:complexType> </xs:element> O exemplo acima indica que o elemento "child_name" pode ocorre no mnimo uma vez (o valor padro para minOccurs 1) e no mximo dez vezes em um elemento "person".
Indicador minOccurs
O indicador <minOccurs> especifica o nmero mnimo de vezes que um elemento pode ocorrer:
<xs:element name="person"> <xs:complexType> <xs:sequence> <xs:element name="full_name" type="xs:string"/> <xs:element name="child_name" type="xs:string" maxOccurs="10" minOccurs="0"/> </xs:sequence> </xs:complexType>
</xs:element> O exemplo acima indica que o elemento "child_name" pode ocorrer um mnimo de zero vezes e um mximo de dez em um elemento "person". Para permitir que um elemento parea um nmero ilimitado de vezes, use a instruo maxOccurs="unbounded":
Um exemplo prtico
Um arquivo XML chamado "Myfamily.xml":
</persons> O arquivo XML acima contm um elemento raiz chamado "persons". Dentro deste elemento est definido vrios elementos "person". Cada elemento "person" deve conter um elemento filho "full_name" e pode conter at cinco elementos filho "child_name". Aqui est o esquema "family.xsd":
<xs:element name="persons"> <xs:complexType> <xs:sequence> <xs:element name="person" maxOccurs="unbounded"> <xs:complexType> <xs:sequence> type="xs:string"/> type="xs:string" <xs:element name="full_name" <xs:element name="child_name" minOccurs="0" maxOccurs="5"/> </xs:sequence> </xs:complexType> </xs:element> </xs:sequence> </xs:complexType> </xs:element>
</xs:schema>
Indicadores de grupo
Indicadores de grupo so usados para definir grupos de elementos relacionados.
Elementos de grupo
Elementos de grupo so definidos com a declarao group, assim:
<xs:group name="groupname"> ... </xs:group> Voc deve deve definir um elemento all, choice, ou sequence dentro da declarao group. O exemplo seguinte define um grupo chamado "persongroup", que define um grupo de elementos que devem ocorrer em uma seqncia exata:
<xs:group name="persongroup"> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> <xs:element name="birthday" type="xs:date"/> </xs:sequence> </xs:group>
Depois que voc definiu um grupo, voc pode referenci-lo na definio de outro grupo ou tipo complexo, assim:
<xs:group name="persongroup"> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> <xs:element name="birthday" type="xs:date"/> </xs:sequence> </xs:group>
<xs:complexType name="personinfo"> <xs:sequence> <xs:group ref="persongroup"/> <xs:element name="country" type="xs:string"/> </xs:sequence> </xs:complexType>
Grupos de atributos
Grupos de atributos so definidos com a declarao attributeGroup, assim:
<xs:attributeGroup name="groupname"> ... </xs:attributeGroup> O exemplo a seguir define um grupo de atributos chamado "personattrgroup":
<xs:attributeGroup name="personattrgroup"> <xs:attribute name="firstname" type="xs:string"/> <xs:attribute name="lastname" type="xs:string"/> <xs:attribute name="birthday" type="xs:date"/> </xs:attributeGroup> Depois que voc definiu um grupo de atributos, voc pode referenci-lo na definio de outro grupo ou tipo complexo, assim:
O elemento <any>
O elemento <any> nos permite extender o documento XML com elementos no especificados no esquema. O exemplo a seguir um fragmento de um esquema XML chamado "family.xsd". Ele mostra uma declarao para o elemento "person". Usando o elemento <any> ns podemos extender (depois de <lastname>) o contedo de "person" com qualquer elemento:
<xs:element name="person"> <xs:complexType> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> <xs:any minOccurs="0"/> </xs:sequence> </xs:complexType> </xs:eleement> Agora ns queremos extender o elemento "person" com um elemento "children". Neste caso ns podemos fazer isto, mesmo que o autor do esquema acima nunca tenha declarado o elemento "children"! Observer esse arquivo de esquema, chamado "children.xsd":
</xs:schema> O arquivo XML abaixo (chamado "Myfamily.xml"), usa componentes de dois esquemas diferentes; "family.xsd" e "children.xsd":
</persons> O arquivo XMl acima vlido porque o esquema "family.xsd" nos permite extender o elemento "person" com um elemento opcional depois do elemento "lastname"! Os elementos <any> e <anyAttribute> so usados para fazer documentos EXTENSVEIS! Eles permitem aos documentos conterem elementos adicionais que no esto declarados no esquema XML!
O elemento <anyAttribute>
O elemento <anyAttribute> nos permite extender o documento XML com atributos que no foram especificados no esquema!
O elemento <anyAttribute>
O elemento <anyAttribute> nos permite extender o documento XML com atributos que no foram especificados no esquema. O exemplo a seguir um fragmento de um esquema XML chamado "family.xsd". Ele mostra uma declarao para o elemento "person". Usando o elemento <anyAttribute> ns podemos adicionar qualquer nmero de atributos ao elemento "person":
<xs:element name="person"> <xs:complexType> <xs:sequence> <xs:element name="firstname" type="xs:string"/> <xs:element name="lastname" type="xs:string"/> </xs:sequence> <xs:anyAttribute/> </xs:complexType> </xs:element> Agora ns queremos extender o elemento "person" com um atributo "gender". Neste caso ns podemos fazer isto, mesmo que o autor do esquema acima nunca tenha declaro nenhum atributo "gender"! Observe este arquivo de esquema, chamado "attribute.xsd":
<xs:attribute name="gender"> <xs:simpleType> <xs:restriction base="xs:string"> <xs:pattern value="male|female"/> </xs:restriction> </xs:simpleType> </xs:attribute>
</xs:schema> O arquivo XML abaixo (chamado "Myfamily.xml"), utiliza componentes de dois esquemas diferentes; "family.xsd" e "attribute.xsd":
</persons> O arquivo XML acima vlido porque o esquema "family.xsd" nos permite adicionar um atributo ao elemento "person"! Os elemento <any> e <anyAttribute> so usado para fazer documentos EXTENSVEIS! Eles permitem aos documentos conterem elementos adicionais que no foram declarados no esquema XML!
Substituio de elementos
Com XML Schemas um elemento pode substituir outro.
Substituio de elementos
Digamos que ns temos usurios de dois paises diferentes: Inglaterra e Noruega. Ns gostaramos de permitir ao usurio escolher se quer usar os nomes de elementos em ingls ou noruegus no documento XML. Para resolver este problema, ns podemos definir um substitutionGroup no esquema XML. Primeiro, n declaramos um elemento chave e ento ns declaramos outros elementos que so substituises para o elemento chave:
<xs:element name="name" type="xs:string"/> <xs:element name="navn" substitutionGroup="name"/> No exemplo acima, o elemento "name" o elemento chave e "navn" o elemento substituvel para "name". Observe esse fragmento de um esquema XML:
<xs:element name="customer" type="custinfo"/> <xs:element name="kunde" substitutionGroup="customer"/> Um documento XML vlido (de acordo com o esquema acima) poderia parecer com isso:
<xs:element name="customer" type="custinfo" block="substituion"/> <xs:element name="kunde" substitutionGroup="customer"/> Um documento XML vlido (de acordo com o esquema acima) parece-se com isso:
Utilizando substitutionGroup
O tipo do elemento de substituio de ver o mesmo, ou derivdo, do tipo do elemento chave. Se o tipo do elemento de substituio o mesmo do elemento chave voc no precisar especific-lo. Note que todos elemento em um substitutionGroup (o elemento chave e os de substituio) de ser declarados como elementos globais, caso contrrio no funcionar!
Um exemplo
Este captulo vai demostrar como escrever um XML Schema. Voc tambm aprender que um esquema pode ser escrito de diferentes maneiras.
Um documento XML
Vamos dar uma olhada nesse documento XML chamado "shiporder.xml":
<address>Langgt 23</address> <city>4000 Stavanger</city> <country>Norway</country> </shipto> <item> <title>Empire Burlesque</title> <note>Special Edition</note> <quantity>1</quantity> <price>10.90</price> </item> <item> <title>Hide your heart</title> <quantity>1</quantity> <price>9.90</price> </item> </shiporder> O documento XML acima consiste de um elemento raiz, "shiporder", que contm um atributo obrigatrio chamado "orderid". O elemento "shiporder" contm trs elementos filhos diferentes: "orderperson", "shipto" e "item". O elemento "item" aparece duas vezes e contm um elemento "title", um elemento opcional "note", um elemento "quantity" e um "price". A linha acima: xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" diz ao parser XML que o documento deve ser vlidado por um esquema. A linha: xsi:noNamespaceSchemaLocation="shiporder.xsd" especifica ONDE o esquema reside (no caso, ele est no mesmo diretrio que "shiporder.xml").
...
...
</xs:schema>
No esquema acima ns usamos o namespace padro (xs), e a URI associada com este namespace na linguagem de definio Schema, que tem o valor padro http://www.w3.org/2001/XMLSchema. Em seguida, ns temos que definir o elemento "shiporder". Este elemento tem um atributo e contm outros elemento, assim o consideramos um tipo complexo. Os elementos filhos de "shiporder" so englobados por um elemento xs:sequence que define uma ordem para eles:
<xs:element name="shiporder"> <xs:complexType> <xs:sequence> ... ... </xs:sequence> </xs:complexType> </xs:element> Ento ns temos que definir o elemento "orderperson" como um tipo simples (porque ele no contm nenhum atributo ou elemento). O tipo (xs:string) prefixado com o prefixo do namespace associado ao XML Schema que indica um tipo de dado pr-definido: <xs:element name="orderperson" type="xs:string"/> Em seguida, ns temos que definir dois elementos que so do tipo complexo: "shipto" e "item". Ns comeamos definindo o elemento "shipto":
<xs:element name="shipto"> <xs:complexType> <xs:sequence> <xs:element name="name" type="xs:string"/> <xs:element name="address" type="xs:string"/> <xs:element name="city" type="xs:string"/> <xs:element name="country" type="xs:string"/> </xs:sequence> </xs:complexType> </xs:element> Com esquemas ns podemos definir o nmero possvel de ocorrncias de um elemento com os atributos maxOccurs e minOccurs. maxOccurs especifica o nmero mximo de ocorrncias para um elemento e minOccurs o nmero mnimo. O valor padro para maxOccurs e minOccurs 1!!! Agora ns podemos definir o elemento "item". Este elemento pode aparecer muitas vezes dentro do elemento "shiporder". Isto especificado definindo o atributo maxOccurs do elemento "item" para "unbounded" que significa que podem haver tantas ocorrncias do elemento "item" quanto o autor desejar. Note que o elemento "note" opcional. Ns especificamos isto definindo o atributo minOccurs em zero:
<xs:element name="item" maxOccurs="unbounded"> <xs:complexType> <xs:sequence> <xs:element name="title" type="xs:string"/> <xs:element name="note" type="xs:string" minOccurs="0"/> <xs:element name="quantity" type="xs:positiveInteger"/> <xs:element name="price" type="xs:decimal"/> </xs:sequence> </xs:complexType> </xs:element> Agora ns podemos declarar o atributo do elemento "shiporder". Como ele um atributo obrigatrio ns especificamos use="required". Nota: As declaras de atributos sempre devem vir no final: <xs:attribute name="orderid" type="xs:string" use="required"/> Aqui est a listagem completa do arquivo schema chamado "shiporder.xsd":
<xs:element name="shiporder"> <xs:complexType> <xs:sequence> <xs:element name="orderperson" type="xs:string"/> <xs:element name="shipto"> <xs:complexType> <xs:sequence> type="xs:string"/> type="xs:string"/> <xs:element name="city" type="xs:string"/> type="xs:string"/> <xs:element name="country" </xs:sequence> </xs:complexType> </xs:element> <xs:element name="item" maxOccurs="unbounded"> <xs:element name="name" <xs:element name="address"
<xs:element name="quantity" type="xs:positiveInteger"/> type="xs:decimal"/> <xs:element name="price" </xs:sequence> </xs:complexType> </xs:element> </xs:sequence> <xs:attribute name="orderid" type="xs:string" use="required"/> </xs:complexType> </xs:element>
</xs:schema>
Divida o schema
O mtodo de design anterior muito simples, mas pode ser muito difcil de ler e manter quando os documentos so complexos! O prximo mtodo de design baseado na definio de todos os elementos e atributos primeiro, e ento referenci-los usando o atributo ref. Aqui est a nova aparncia o arquivo de esquema ("shiporder.xsd"):
<!-- definio de elementos simples --> <xs:element name="orderperson" type="xs:string"/> <xs:element name="name" type="xs:string"/> <xs:element name="address" type="xs:string"/> <xs:element name="city" type="xs:string"/> <xs:element name="country" type="xs:string"/> <xs:element name="title" type="xs:string"/> <xs:element name="note" type="xs:string"/> <xs:element name="quantity" type="xs:positiveInteger"/> <xs:element name="price" type="xs:decimal"/>
<!-- definio de elementos complexos --> <xs:element name="shipto"> <xs:complexType> <xs:sequence> <xs:element ref="name"/> <xs:element ref="address"/> <xs:element ref="city"/> <xs:element ref="country"/> </xs:sequence> </xs:complexType> </xs:element> <xs:element name="item"> <xs:complexType> <xs:sequence> <xs:element ref="title"/> <xs:element ref="note" minOccurs="0"/> <xs:element ref="quantity"/> <xs:element ref="price"/> </xs:sequence> </xs:complexType> </xs:element>
<xs:element name="shiporder"> <xs:complexType> <xs:sequence> <xs:element ref="orderperson"/> <xs:element ref="shipto"/> <xs:element ref="item" maxOccurs="unbounded"/> </xs:sequence> <xs:attribute ref="orderid" use="required"/> </xs:complexType> </xs:element>
</xs:schema>
O terceiro mtodo de design define classes e tipos, que nos permite reutilizar a definio de elementos. Isto feito nomeando os elementos simpleTypes e complexTypes, e ento apontando para eles com o atributo type do elemento. Aqui est a nova forma do arquivo de esquema ("shiporder.xsd"):
<xs:complexType name="shiptotype"> <xs:sequence> <xs:element name="name" type="stringtype"/> <xs:element name="address" type="stringtype"/> <xs:element name="city" type="stringtype"/> <xs:element name="country" type="stringtype"/> </xs:sequence> </xs:complexType>
<xs:complexType name="itemtype"> <xs:sequence> <xs:element name="title" type="stringtype"/> <xs:element name="note" type="stringtype"/> <xs:element name="quantity" type="inttype"/>
<xs:complexType name="shipordertype"> <xs:sequence> <xs:element name="orderperson" type="stringtype"/> <xs:element name="shipto" type="shiptotype"/> <xs:element name="item" maxOccurs="unbounded" type="itemtype"/> </xs:sequence> <xs:attribute name="orderid" type="orderidtype" use="required"/> </xs:complexType>
</xs:schema> O elemento restriction indica que o tipo de dado derivado de um namespace de XML Schema do W3C. Assim, esse fragmento: <xs:restriction base="xs:string"/> significa que o valor do elemento ou atributo de ser uma string. O elemento restriction costuma ser mais usado para aplicar restries nos elementos. Observe as seguintes linhas do esquema acima:
<xs:simpleType name="orderidtype"> <xs:restriction base="xs:string"> <xs:pattern value="[0-9]{6}"/> </xs:restriction> </xs:simpleType> Isto indica que o valor do elemento ou atributo deve ser uma string e deve exatamente seis caracteres e cada caracter deve ser um nmero entre 0 e 9.
<xs:element name="customer" type="xs:string"/> Um elemento em seu documento poderia ser assim: <customer>John Smith</customer> Ou assim: <customer> John Smith </customer>
Nota: O processador XML no vai modificar o valor se voc usar o tipo de dado string.
ENTITY ID IDREF IDREFS language Name NCName NMTOKEN NMTOKENS normalizedString QName string token Uma cadeia de caracteres Um string que no contm quebras de linhs, retornos de carro, tabulao, espaos iniciais e finais, ou mltiplos espaos Uma string que no contm quebras de linha, retornos de carro, ou tabulao Uma string que representa o atributo NMTOKEN em XML (usado apenas com atributos schema) Uma string que contm a id de uma linguagem vlida Uma string que contm um nome XML vlido Uma string que representa o atributo ID em XML (usado apenas com atributos de schema) Uma string que representa o atributo IDREF em XML (usado apenas com atributos schema)
Nota: Todos componentes so obrigatrios! A seguir est um exemplo de declarao uma data em um schema:
<xs:element name="start" type="xs:date"/> Um elemento em seu documento poderia ser assim: <start>2002-09-24</start>
Time zones
Para especificar um time zone (fuso horrio), voc pode usar uma data no horrio UTC adicionando um "Z" depois da data, como aqui: <start>2002-09-24Z</start> ou voc pode especificar uma rea do horrio UTC adicionando um horrio positivo ou negativo depois da data, como aqui:
<start>2002-09-24-06:00</start>
ou
<start>2002-09-24+06:00</start>
Nota: Todos componentes so obrigatrios! A seguir est um exemplo de declarao de um time em em schema: <xs:element name="start" type="xs:time"/> Um elemento em seu documento poderia ser assim: <start>09:00:00</start> Ou assim: <start>09:30:10.5</start>
Time zones
Para especificar um time zone (fuso horrio), voc pode tanto usar um horrio em UTC, adicionando um "Z" ao final dele, como aqui: <start>09:30:10Z</start> ou especificando uma rea do horrio UTC, adicionando um horrio positivo ou negativo depois dele, como aqui:
<start>09:30:10-06:00</start>
ou
<start>09:30:10+06:00</start>
Nota: Todos componentes so obrigatrios! A seguir est um exemplo de uma declarao dateTime em um schema: <xs:element name="stardate" type="xs:dateTime"/> Um elemento em seu documento poderia ser assim: <startdate>2002-05-30T09:00:00</startdate> Ou assim: <startdate>2002-05-30T09:30:10.5</startdate>
Time zones
Para especificar um time zone (fuso horrio), voc pode tanto utilizar um dateTime em UTC adicionado de um "Z", como aqui: <startdate>2002-05-30T09:30:10Z</startdate> ou especificando uma rea do horrio UTC, adicionando um horrio positivo ou negativo ao horrio, como aqui:
<startdate>2002-05-30T09:30:10-06:00</startdate>
ou
<startdate>2002-05-30T09:30:10+06:00</startdate>
A seguir est um exemplo de uma declarao de duration em um schema: <xs:element name="period" type="duration"/> Um elemento em seu documento poderia ser assim: <period>P5Y</period> O exemplo acima indica um perodo de cinco anos. Ou assim: <period>P5Y2M10D</period> O exemplo acima indica um perodo de cinco anos, dois meses e dez dias. Ou assim: <period>P5Y2M10DT15H</period> O exemplo acima indica um perodo de cinco anos, dois meses, dez dias e 15 horas. Ou assim: <period>PT15H</period> O exemplo acima indica um perodo de 15 horas.
Durao negativa
Para especificar uma durao negativa, insira um sinal de menos antes de P: <period>-P10D</period> O exemplo acima indica um perodo de menos 10 dias.
Define um valor de data e hora Define um intervalo de tempo Define uma parte de uma data - o dia (DD) Define uma parte de uma data - o ms (MM) Define uma parte de uma data - o ms e o dia (MM-DD) Define uma parte de uma data - o ano (YYYY)
gYearMonth Define uma parte de uma data - o ano e o ms (YYYY-MM) time Define um valor de hora
Nota: O nmero mximo de dgitos decimais que voc pode especificar 18!
nonNegativeInteger Um inteiro contendo apenas valores no negativos (0, 1, 2, ...) nonPositiveInteger positiveInteger short unsignedLong unsignedInt unsignedShort unsignedByte Um inteiro contendo apenas valores no positivos (..., -2, -1, 0) Um inteiro contendo apenas valores positivos (1, 2, ...) Um inteiro 16-bit com sinal Um inteiro 64-bit sem sinal Um inteiro 32-bit sem sinal Um inteiro 16-bit sem sinal Um inteiro 8-bit sem sinal
<pic src="http://www.w3schools.com/images/smiley.gif" /> Nota: Se uma URI tem espaos, substitua-os por %20.
Validador XSD
Validador XSD