XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Show tree view Topic
Topic Page 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 Go to previous topicPrev TopicGo to next topicNext Topic
Postnext
Paul CorriveauSubject: Unable to create a complex type with facets and element children
Author: Paul Corriveau
Date: 07 May 2008 09:09 AM
Thanks for taking the time to look at this. I've been struggling with this and am about to say "it can't be done", but I wanted to run it by you all first in the hopes that you might have some ideas.

Here is the goal:
<Root>
<Code description="New">1
<Transaction>
<theId>id</theId>
</Transaction>
</Code>
</Root>

I need a type that will:
1.) Allow simple content (strings, decimal, etc) with attributes
2.) Allow that content to be contrained with facets (maxLength, totalDigits, etc.),
3.) Allow that type to have element children.

The problem is that I can create a type that will do 1 and 3 above, but as soon as I introduce the ability to do 3 (element children), the ability to do 2 (constrain with facetcs) drops right off the face of the earth. Below is how I arrived at this:

Using the sample document above, pretend that it does not have the Transactions chile element, so the Code element would look like this.

<Code description="New">1</Code>


I created a type to support the above element, and that supports the #1 item above. It looks like this:

<xs:complexType name="stringWithAttributeType">
<xs:simpleContent>
<xs:extension base="xs:string">
<xs:attribute name="description"/>
</xs:extension>
</xs:simpleContent>
</xs:complexType>

All is well with the world at this point, the string element with attribute validates fine.

I then move on to my second goal, which is to constrain the above. I create a new type derived from the above that looks like this:

<xs:complexType name="constrainLengthType">
<xs:simpleContent>
<xs:restriction base="stringWithAttributeType">
<xs:maxLength value="1"/>
</xs:restriction>
</xs:simpleContent>
</xs:complexType>


I have contrained the length of the string to 1 and all is working fine at this point. The simple attributed string element that validated before still validates. The element below:

<Code description="New">12</Code>

will fail validation because the two character length of the string violates the maxLength facet.

So, #1 and #2 goal are working fine. I move on to add the element children. I have another complex type that defines what I want that element child to look like. I believe it is mostly irrelevant, but here it is:

<xs:complexType name="TransType">
<xs:sequence>
<xs:element name="theId" type="xs:string"/>
</xs:sequence>
</xs:complexType>


I use that type as part of the extension to the type I built above that has worked to satisfy my #1 and #2 goals. That type looks like this:

<xs:complexType name="addElementChildrenType">
<xs:complexContent mixed="true">
<xs:extension base="constrainLengthType">
<xs:sequence>
<xs:element name="Transaction" type="TransType"/>
</xs:sequence>
</xs:extension>
</xs:complexContent>
</xs:complexType>

So, I take the type defined for #2 above and extend it to add the ability to have an element of type TransType. Looking back at the original document:

<Root>
<Code description="New">1
<Transaction>
<theId>id</theId>
</Transaction>
</Code>
</Root>


All is well, it validates, choruses of uneartly voices are singing slightly out of my perception and I'm ready to go home for the day confident that the problem has been solved. However... altering the above to change the value of the the Code element from one character to two character, just to be sure it still catches the problem and that the constraint is working, reveals that the existence of the constraint has completely dropped off the radar and the document will validate, no matter what I put in there.

Thanks for taking the time to read this. I apologize for the length, but I was aiming for clarity. If I have accomplished neither brevity nor clarity, well then, I guess I *really* apologize then.

Any thoughts?

Posttop
Alberto MassariSubject: Unable to create a complex type with facets and element children
Author: Alberto Massari
Date: 08 May 2008 03:21 PM
Hi Paul,
when you add mixed=true you are allowing any non-whitespace text to be present between the elements making the complex type, and you cannot validate them separately anymore. Unfortunately, XMLSchema doesn't support the structure you want to achieve.

Alberto

 
Topic Page 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 Go to previous topicPrev TopicGo to next topicNext Topic
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.