473,395 Members | 1,823 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,395 software developers and data experts.

what is wrong with this?

Hi,

Can someone please help me explain, why this doesn't work? The problem is
the xs:key and xs:keyref. I can only reference the last of the
"afsnit"-nodes (number 302). Whenever I try to reference number 301, I get
the error: 'Undefined values for keyref identity constraint AfsnitFK' (using
xmlspy 2003).

Why, oh why?

----------------------------------------------------------------------------
--

<?xml version="1.0" encoding="UTF-8"?>
<kalkulation xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="s.xsd">
<tilbudsliste>
<afsnit id="301">
<navn>a</navn>
</afsnit>
<afsnit id="302">
<navn>b</navn>
</afsnit>
</tilbudsliste>
<pris afsnit="302"/>
</kalkulation>

------------------------------
s.xsd --------------------------------------------

<?xml version="1.0" encoding="ISO-8859-1"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="afsnit">
<xs:complexType>
<xs:sequence>
<xs:element name="navn" type="xs:string"/>
</xs:sequence>
<xs:attribute name="id" type="xs:string"/>
</xs:complexType>
<xs:key name="afsnitPK">
<xs:selector xpath="."/>
<xs:field xpath="@id"/>
</xs:key>
</xs:element>
<xs:element name="tilbudsliste">
<xs:complexType>
<xs:sequence>
<xs:element ref="afsnit" maxOccurs="unbounded"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="pris">
<xs:complexType>
<xs:attribute name="afsnit" type="xs:string"/>
</xs:complexType>
<xs:keyref name="afsnitFK" refer="afsnitPK">
<xs:selector xpath="."/>
<xs:field xpath="@afsnit"/>
</xs:keyref>
</xs:element>
<xs:element name="kalkulation">
<xs:complexType>
<xs:sequence>
<xs:element ref="tilbudsliste"/>
<xs:element ref="pris" maxOccurs="unbounded"/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
Jul 20 '05 #1
1 1381
stormogulen wrote:
Can someone please help me explain, why this doesn't work? The problem is
the xs:key and xs:keyref. I can only reference the last of the
"afsnit"-nodes (number 302). Whenever I try to reference number 301, I get
the error: 'Undefined values for keyref identity constraint AfsnitFK' (using
xmlspy 2003).

Why, oh why?


This location of the xs:key element in the schema gives the context node in
which the constraint holds, with the constraint as you have it defined, you can
even insert multiple afsnit elements with the same ID (since the key is only
defined for each element).

If you place the xs:key in the containing element with a selector selecting
afsnit, it will work just as you expect it:

<xs:element name="tilbudsliste">
<xs:complexType>
<xs:sequence>
<xs:element ref="afsnit" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
<xs:key name="afsnitPK">
<xs:selector xpath="afsnit" />
<xs:field xpath="@id" />
</xs:key>
</xs:element>

<xs:element name="afsnit">
<xs:complexType>
<xs:sequence>
<xs:element name="navn" type="xs:string" />
</xs:sequence>
<xs:attribute name="id" type="xs:string" />
</xs:complexType>
</xs:element>

(remainder of your XSD file unchanged)

Hope this helps

--
Klaus Johannes Rusch
Kl********@atmedia.net
http://www.atmedia.net/KlausRusch/
Jul 20 '05 #2

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

3
by: Mike Henley | last post by:
I first came across rebol a while ago; it seemed interesting but then i was put off by its proprietary nature, although the core of the language is a free download. Recently however, i can't...
72
by: E. Robert Tisdale | last post by:
What makes a good C/C++ programmer? Would you be surprised if I told you that it has almost nothing to do with your knowledge of C or C++? There isn't much difference in productivity, for...
121
by: typingcat | last post by:
First of all, I'm an Asian and I need to input Japanese, Korean and so on. I've tried many PHP IDEs today, but almost non of them supported Unicode (UTF-8) file. I've found that the only Unicode...
28
by: Madhur | last post by:
Hello what about this nice way to open a file in single line rather than using if and else. #include<stdio.h> void main() { FILE *nd; clrscr();...
9
by: Pyenos | last post by:
import cPickle, shelve could someone tell me what things are wrong with my code? class progress: PROGRESS_TABLE_ACTIONS= DEFAULT_PROGRESS_DATA_FILE="progress_data" PROGRESS_OUTCOMES=
3
by: Siong.Ong | last post by:
Dear all, my PHP aims to update a MySQL database by selecting record one by one and modify then save. Here are my PHP, but I found that it doesnt work as it supposed to be, for example, when...
89
by: Tubular Technician | last post by:
Hello, World! Reading this group for some time I came to the conclusion that people here are split into several fractions regarding size_t, including, but not limited to, * size_t is the...
20
by: Daniel.C | last post by:
Hello. I just copied this code from my book with no modification : #include <stdio.h> /* count characters in input; 1st version */ main() { long nc; nc = 0;
24
by: MU | last post by:
Hello I have some code that sets a dropdownlist control with a parameter from the querystring. However, when the querystring is empty, I get an error. Here is my code: Protected Sub...
2
by: mingke | last post by:
Hi... So I have problem with my if condition..I don't know what's wrong but it keeps resulting the wrong answer.... So here's the part of my code I have problem with: for (i=0; i<size2;...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.