File: ms_a_3.xml

package info (click to toggle)
virtuoso-opensource 6.1.4%2Bdfsg1-7
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 245,116 kB
  • sloc: ansic: 639,631; sql: 439,225; xml: 287,085; java: 61,048; sh: 38,723; cpp: 36,889; cs: 25,240; php: 12,562; yacc: 9,036; lex: 7,149; makefile: 6,093; jsp: 4,447; awk: 1,643; perl: 1,017; ruby: 1,003; python: 329
file content (126 lines) | stat: -rw-r--r-- 6,054 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<!--
 -  
 -  This file is part of the OpenLink Software Virtuoso Open-Source (VOS)
 -  project.
 -  
 -  Copyright (C) 1998-2006 OpenLink Software
 -  
 -  This project is free software; you can redistribute it and/or modify it
 -  under the terms of the GNU General Public License as published by the
 -  Free Software Foundation; only version 2 of the License, dated June 1991.
 -  
 -  This program is distributed in the hope that it will be useful, but
 -  WITHOUT ANY WARRANTY; without even the implied warranty of
 -  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 -  General Public License for more details.
 -  
 -  You should have received a copy of the GNU General Public License along
 -  with this program; if not, write to the Free Software Foundation, Inc.,
 -  51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
 -  
 -  
-->
<?xml version="1.0" encoding="ISO-8859-1"?>
<refentry id="MS-A-3">
  <refmeta>
    <refentrytitle>Using Annotated XSD Schemas for Creating XML Views</refentrytitle>
    <refmiscinfo>tutorial</refmiscinfo>
  </refmeta>
  <refnamediv>
    <refname></refname>
    <refpurpose>Using sql:relationship to Specify Relationships</refpurpose>
  </refnamediv>

<refsect1 id="MS-A-3a">
<title>Preliminaries</title>
<para>
In the annotated XSD schema, the sql:relationship annotation is used to nest the schema elements hierarchically, 
on the basis of primary key and foreign key relationships among the underlying tables to which the elements map. 
In specifying the sql:relationship annotation, you must identify: 
 The parent table (Customers) and the child table (Orders).
 The necessary join condition. (CustomerID in Orders is a child key that refers to the CustomerID parent key in the Customers table.) 

This information is used in generating the proper hierarchy. (For each parent element, the related child 
elements appear as subelements.)
To provide the table names and the necessary join information, the following attributes are specified on the 
sql:relationship annotation: </para>
<itemizedlist mark="bullet">
  <listitem> 
&apos;name&apos; specifies the unique name of the relationship;
  </listitem>
  <listitem>&apos;parent&apos; specifies the parent relation (table). This is an optional attribute; if the attribute is not specified, the parent 
table name is obtained from information in the child hierarchy in the document. If the schema specifies two 
parent-child hierarchies that use the same &lt;sql:relationship&gt; but different parent elements, you do not specify 
the parent attribute in &lt;sql:relationship&gt;. This information is obtained from the hierarchy in the schema.
  </listitem>
  <listitem> &apos;parent-key&apos; specifies the parent key of the parent. If the parent key is composed of multiple columns, values are specified 
with a space between them. There is a positional mapping between the values that are specified for the multicolumn 
key and for the corresponding child key.
  </listitem>
  <listitem>&apos;child&apos; specifies the child relation (table).
  </listitem>
  <listitem>&apos;child-key&apos; specifies the child key in the child referring to parent-key in parent. If the child key is composed of multiple 
attributes (columns), the child-key values are specified with a space between them. There is a positional 
mapping between the values that are specified for the multicolumn key and for the corresponding parent key.
  </listitem>
</itemizedlist>
<para>These attributes are valid only with the &lt;sql:relationship&gt; element.
</para>

</refsect1>
<refsect1 id="MS-A-3b">
<title>Example. Specifying the sql:relationship annotation on an element.</title>
<para>
The following annotated XSD schema includes &apos;Customer&apos; and &apos;Order&apos; elements. 
The &apos;Order&apos; element is a subelement of the &apos;Customer&apos; element.
In the schema, the sql:relationship annotation is specified on the &apos;Order&apos; subelement. The relationship 
itself is defined in the &apos;appinfo&apos; element.
The &apos;relationship&apos; element identifies CustomerID in the Orders table as a foreign key that refers to the 
CustomerID primary key in the Customers table. Therefore, orders that belong to a customer appear as a subelement of 
that &apos;Customer&apos; element.
</para>
<programlisting><![CDATA[
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
            xmlns:sql="urn:schemas-microsoft-com:mapping-schema">
<xsd:annotation>
  <xsd:appinfo>
    <sql:relationship name="CustOrders"
          parent="Demo.demo.Customers"
          parent-key="CustomerID"
          child="Demo.demo.Orders"
          child-key="CustomerID" />
  </xsd:appinfo>
</xsd:annotation>

  <xsd:element name="Customer" sql:relation="Demo.demo.Customers" type="CustomerType" />
   <xsd:complexType name="CustomerType" >
     <xsd:sequence>
        <xsd:element name="Order" 
                     sql:relation="Demo.demo.Orders"
                    sql:relationship="CustOrders" >
           <xsd:complexType>
              <xsd:attribute name="OrderID" type="xsd:integer" />
              <xsd:attribute name="CustomerID" type="xsd:string" />
           </xsd:complexType>
        </xsd:element>
     </xsd:sequence>
        <xsd:attribute name="CustomerID"   type="xsd:string" /> 
        <xsd:attribute name="ContactName"  type="xsd:string" />
    </xsd:complexType>
</xsd:schema>
]]></programlisting>
<para>Let the schema is written to the file &apos;CustOr_constant.xsd&apos;, then after loading this file by 
<function>xml_load_mapping_schema_decl</function> function, the first example will produce a result for the XPath query:
</para>
<programlisting><![CDATA[
XPATH [__view 'Customer_Order'] /Customer[@CustomerID="QUEEN"];
]]></programlisting>
<para>
the second example will produce a result for the XQuery query:
</para>
<programlisting><![CDATA[
select xquery_eval('<doc>{for $r in xmlview("Customer_Order")/*[@CustomerID="QUEEN"] return $r}</doc>', xtree_doc('<q/>'))
]]></programlisting>

</refsect1>
</refentry>