Project

General

Profile

« Previous | Next » 

Revision 34

added example files showing use of Oracle's XSQL utiltiy for metadata storage and retrieval

View differences:

xsqltest/contents.html
1
<!--
2
  * contents.html
3
  *
4
  *      Authors: Matt Jones
5
  *    Copyright: 2000 Regents of the University of California and the
6
  *               National Center for Ecological Analysis and Synthesis
7
  *  For Details: http://www.nceas.ucsb.edu/
8
  *      Created: 2000 April 5
9
  *      Version: 0.01
10
  *    File Info: '$Id$'
11
  * 
12
  * This is an HTML document for displaying examples of the use of 
13
  * Oracle XML tools
14
-->
15
<html>
16
<head>
17
<title>XSL Transformation and formatting examples</title>
18
</head>
19
<body bgcolor="white">
20
<B>XSL Transformation and formatting examples -- Oracle tools</B><P>
21
<B>Example 1</B><BR>
22
Simple database query against Oracle8i<BR>
23
<UL>
24
<LI>View <A HREF="xmltest2.xsql" TARGET="right">XSL transformed html output</A>
25
<LI>View <A HREF="xmltest2.xsql?xml-stylesheet=none" 
26
	    TARGET="right">raw xml output</A>
27
<LI>View <A HREF="xmltest2-xsql.xml" TARGET="right">XSQL source</A>
28
<LI>View <A HREF="rowcol.xsl" TARGET="right">XSL source</A>
29
</UL>
30
<P>
31
<B>Example 2</B><BR>
32
Simple eml-dataset display from Oracle8i database<BR>
33
<p><i>Note: these examples are not actually valid according to
34
eml-dataset.dtd, but they are close and I am working on it...</i></p>
35
<UL>
36
<LI>View <A HREF="dsquery.xsql" TARGET="right">Dynamic query (html output)</A>
37
<LI>View <A HREF="dsquery.xsql?xml-stylesheet=none" TARGET="right">Dynamic query (raw xml output)</A>
38
<LI>View <A HREF="dsquery-xsql.xml" TARGET="right">Dynamic query (XSQL source)</A>
39
<LI>View <A HREF="dsquery.xsl" TARGET="right">Dynamic query (XSL source)</A>
40
<LI>View <A HREF="eml-dataset2.xsql" 
41
    TARGET="right">XSL transformed html output</A>
42
<LI>View <A HREF="eml-dataset1.xsql?meta_file_id=NCEAS-1998-2244-Dist-Dataset" 
43
    TARGET="right">transformed xml output</A>
44
<LI>View <A HREF="eml-dataset1.xsql?meta_file_id=NCEAS-1998-2244-Dist-Dataset&xml-stylesheet=none" TARGET="right">raw xml output</A>
45
<LI>View <A HREF="eml-dataset1-xsql.xml" TARGET="right">XSQL source</A>
46
<LI>View <A HREF="eml-dataset.xsl" TARGET="right">XSL source (XML to XML)</A>
47
<LI>View <A HREF="eml-dataset-display.xsl" TARGET="right">XSL source (XML to HTML)</A>
48
</UL>
49
<P>
50
</body>
51
</html>
0 52

  
xsqltest/dsquery-xsql.xml
1
<?xml version = '1.0'?>
2
<!--
3
  * dsquery.xsql
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSQL (http://technet.oracle.com/tech/xml) document designed
14
  * to query a relational database and return the result as a well-formed
15
  * XML document. The query is a general search for datasets that match
16
  * search criteria from a metadata catalog containing documents that are 
17
  * valid with respect to the eml-dataset.dtd module of the Ecological 
18
  * Metadata Language (EML)
19
-->
20
<html connection="demo" xmlns:xsql="urn:oracle-xsql">
21
<head><title>Query Demo</title></head>
22
<body>
23
<section>Query form</section>
24
<form>
25
  <method>POST</method>
26
  <action>/xsqltest/dsquery.xsql</action>
27
  <textfield>
28
    <name>search_string</name>
29
    <xsql:query tag-case="lower" 
30
                rowset-element="" row-element="" id-attribute="">
31
       select '{@search_string}' AS val FROM DUAL
32
    </xsql:query>
33
  </textfield>
34
  <input type="submit" name="Run query"/>
35
</form>
36
<section>Results</section>
37
<xsql:query tag-case="lower">
38

  
39
  SELECT meta_file_id,dataset_id,title, 
40
         CURSOR (SELECT salutation,given_name,surname
41
                   FROM party_individual pi
42
                  WHERE pi.party_individual_id IN
43
                        (SELECT party_individual_id FROM party p
44
                          WHERE p.meta_file_id = ds.meta_file_id)) as originators 
45
    FROM eml_dataset ds
46
   WHERE UPPER(meta_file_id) LIKE UPPER('%{@search_string}%')
47
      OR UPPER(dataset_id)  LIKE UPPER('%{@search_string}%')
48
      OR UPPER(title)  LIKE UPPER('%{@search_string}%')
49
      OR UPPER(abstract) LIKE UPPER('%{@search_string}%')
50
</xsql:query>
51
</body>
52
</html>
0 53

  
xsqltest/dsquery.xsl
1
<?xml version="1.0"?>
2
<!--
3
  * dsquery.xsl
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the 
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  *
13
  * This is an XSLT (http://www.w3.org/TR/xslt) stylesheet designed to
14
  * convert an XML file listing datasets returned from a database query
15
  * into an HTML format suitable for rendering with modern web browsers.
16
-->
17
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
18

  
19
  <xsl:output method="html"/>
20

  
21
  <xsl:template match="/">
22
     <html>
23
       <head>
24
         <title><xsl:value-of select="//head/title"/></title>
25
	 <link rel="stylesheet" type="text/css" href="./rowcol.css" />
26
       </head>
27
       <body class="eml-dataset"> 
28
         <xsl:apply-templates/>      
29
       </body>
30
     </html>
31
  </xsl:template>
32

  
33
  <xsl:template match="form">
34
    <form>
35
       <xsl:attribute name="method">
36
         <xsl:value-of select="method"/>
37
       </xsl:attribute>
38
       <xsl:attribute name="action">
39
         <xsl:value-of select="action"/>
40
       </xsl:attribute>
41
       <xsl:apply-templates/>
42
    </form>
43
  </xsl:template>
44

  
45
  <xsl:template match="method">
46
  </xsl:template>
47

  
48
  <xsl:template match="action">
49
  </xsl:template>
50

  
51
  <xsl:template match="textfield">
52
    <input type="text">
53
      <xsl:attribute name="name"><xsl:value-of select="name"/></xsl:attribute>
54
      <xsl:attribute name="value"><xsl:value-of select="val"/></xsl:attribute>
55
    </input>
56
  </xsl:template>
57

  
58
  <xsl:template match="input">
59
    <xsl:copy-of select="."/>
60
  </xsl:template>
61

  
62
  <xsl:template match="section">
63
    <h2><xsl:value-of select="."/></h2>
64
  </xsl:template>
65

  
66
  <xsl:template match="//head/title"/>
67

  
68
  <xsl:template match="meta_file_id">
69
    <a>
70
    <xsl:attribute name="href">/xsqltest/eml-dataset2.xsql?meta_file_id=<xsl:value-of select="."/></xsl:attribute>
71
    <xsl:value-of select="."/>
72
    </a>
73
  </xsl:template>
74

  
75
  <xsl:template match="originators">
76
    <xsl:for-each select="originators_row">
77
      <xsl:value-of select="salutation"/> 
78
      <xsl:text> </xsl:text>
79
      <xsl:value-of select="given_name"/> 
80
      <xsl:text> </xsl:text>
81
      <xsl:value-of select="surname"/>
82
      <xsl:if test="not(position()=last())">, </xsl:if> 
83
    </xsl:for-each>
84
  </xsl:template>
85

  
86
    <xsl:template match="rowset">
87
      <center>
88
      <table border="0" cellpadding="4">
89
      <xsl:choose>
90
        <xsl:when test="row">
91
	  <xsl:for-each select="row[1]">
92
	    <tr>
93
	      <xsl:for-each select="*[not(starts-with(name(.),'H_'))]">
94
		<th align="left">
95
		  <xsl:attribute name="class">
96
		    <xsl:choose>
97
		      <xsl:when test="position() mod 2 = 1">colodd</xsl:when>
98
		      <xsl:when test="position() mod 2 = 0">coleven</xsl:when>
99
		    </xsl:choose>
100
		  </xsl:attribute>
101
		  <xsl:value-of select="name(.)"/>
102
		</th>
103
	      </xsl:for-each>
104
	    </tr>
105
	  </xsl:for-each>
106
	  <xsl:apply-templates/>
107
        </xsl:when>
108
        <xsl:otherwise>
109
          <tr><td>No Matches</td></tr> 
110
        </xsl:otherwise>
111
      </xsl:choose>
112
      </table>
113
      </center>
114
    </xsl:template>
115

  
116
    <xsl:template match="row">
117
        <tr>
118
          <xsl:attribute name="class">
119
            <xsl:choose>
120
              <xsl:when test="position() mod 2 = 1">rowodd</xsl:when>
121
              <xsl:when test="position() mod 2 = 0">roweven</xsl:when>
122
            </xsl:choose>
123
          </xsl:attribute>
124
          <xsl:attribute name="valign">
125
            top
126
          </xsl:attribute>
127

  
128
          <xsl:for-each select="*[not(starts-with(name(.),'H_'))]">
129
            <td>
130
	      <xsl:attribute name="class">
131
		<xsl:choose>
132
		  <xsl:when test="position() mod 2 = 1">colodd</xsl:when>
133
		  <xsl:when test="position() mod 2 = 0">coleven</xsl:when>
134
		</xsl:choose>
135
	      </xsl:attribute>
136
              <xsl:apply-templates select='.'/>
137
            </td>
138
          </xsl:for-each>
139
        </tr>
140
  </xsl:template>
141

  
142
</xsl:stylesheet>
0 143

  
xsqltest/dsquery.xsql
1
<?xml version = '1.0'?>
2
<!--
3
  * dsquery.xsql
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSQL (http://technet.oracle.com/tech/xml) document designed
14
  * to query a relational database and return the result as a well-formed
15
  * XML document. The query is a general search for datasets that match
16
  * search criteria from a metadata catalog containing documents that are 
17
  * valid with respect to the eml-dataset.dtd module of the Ecological 
18
  * Metadata Language (EML)
19
-->
20
<?xml-stylesheet type="text/xsl" href="dsquery.xsl"?>
21
<html connection="demo" xmlns:xsql="urn:oracle-xsql">
22
<head><title>Query Demo</title></head>
23
<body>
24
<section>Query form</section>
25
<form>
26
  <method>POST</method>
27
  <action>/xsqltest/dsquery.xsql</action>
28
  <textfield>
29
    <name>search_string</name>
30
    <xsql:query tag-case="lower" 
31
                rowset-element="" row-element="" id-attribute="">
32
       select '{@search_string}' AS val FROM DUAL
33
    </xsql:query>
34
  </textfield>
35
  <input type="submit" name="Run query"/>
36
</form>
37
<section>Results</section>
38
<xsql:query tag-case="lower">
39

  
40
  SELECT meta_file_id,dataset_id,title, 
41
         CURSOR (SELECT salutation,given_name,surname
42
                   FROM party_individual pi
43
                  WHERE pi.party_individual_id IN
44
                        (SELECT party_individual_id FROM party p
45
                          WHERE p.meta_file_id = ds.meta_file_id)) as originators 
46
    FROM eml_dataset ds
47
   WHERE UPPER(meta_file_id) LIKE UPPER('%{@search_string}%')
48
      OR UPPER(dataset_id)  LIKE UPPER('%{@search_string}%')
49
      OR UPPER(title)  LIKE UPPER('%{@search_string}%')
50
      OR UPPER(abstract) LIKE UPPER('%{@search_string}%')
51
</xsql:query>
52
</body>
53
</html>
0 54

  
xsqltest/eml-dataset.xsl
1
<?xml version="1.0"?>
2
<!--
3
  * eml-dataset.xsl
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSLT (http://www.w3.org/TR/xslt) stylesheet designed to
14
  * convert an XML file that is the result of a SQL query using Oracle's
15
  * XSQL tool to another XML file that is valid with respect to the 
16
  * eml-dataset.dtd module of Ecological Metadata Language (EML)
17
-->
18
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
19

  
20
  <xsl:template match="/">
21
    <?xml-stylesheet type="text/xsl" href="eml-dataset-display.xsl"?>
22
    <eml-dataset>
23
      <xsl:apply-templates/>      
24
    </eml-dataset>
25
  </xsl:template>
26

  
27
  <xsl:template match="originator">
28
    <originator>
29
      <xsl:choose>
30
      <xsl:when test="party_org">
31
          <party><party_org><xsl:value-of select="."/></party_org></party>
32
      </xsl:when>
33
        <xsl:otherwise>
34
          <party>
35
            <party_individual>
36
              <xsl:for-each select="salutation|given_name|surname|jobtitle">
37
                 <xsl:copy-of select="."/>
38
              </xsl:for-each>
39
            </party_individual>
40
          </party>
41
        </xsl:otherwise>
42
      </xsl:choose>
43
      <meta_address>
44
        <xsl:for-each select="address|city|admin_area|postal_code|country|resource_url|email|work_phone|home_phone|fax|tdd_phone">
45
           <xsl:copy-of select="."/>
46
        </xsl:for-each>
47
      </meta_address>
48
    </originator> 
49
  </xsl:template>
50

  
51
  <xsl:template match="meta_file_id|dataset_id|title|abstract|keyword_info">
52
    <xsl:copy-of select="."/>
53
  </xsl:template>
54

  
55
</xsl:stylesheet>
0 56

  
xsqltest/eml-dataset1-xsql.xml
1
<?xml version="1.0"?>
2
<!--
3
  * eml-dataset1.xsql
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSQL (http://technet.oracle.com/tech/xml) document designed
14
  * to query a relational database and return the result as a well-formed
15
  * XML document that contains the information necessary to transform the
16
  * document into the eml-dataset.dtd module of the Ecological Metadata
17
  * Language (EML)
18
-->
19
<eml-dataset connection="demo" xmlns:xsql="urn:oracle-xsql">
20

  
21
<xsql:query tag-case="lower" 
22
            rowset-element="" 
23
            row-element="" 
24
            id-attribute="">
25

  
26
  SELECT meta_file_id,dataset_id,title FROM eml_dataset
27
   WHERE meta_file_id = '{@meta_file_id}'
28

  
29
</xsql:query>
30

  
31
<xsql:query tag-case="lower" 
32
            row-element="originator" 
33
            rowset-element="" 
34
            id-attribute="">
35

  
36
  SELECT p.party_org, pi.salutation, pi.given_name, pi.surname, pi.jobtitle, 
37
         ma.address, ma.city, ma.admin_area, ma.postal_code, ma.country,
38
         ma.resource_url, ma.email, ma.work_phone, ma.home_phone, ma.fax,
39
         ma.tdd_phone 
40
    FROM party p, party_individual pi, meta_address ma
41
   WHERE p.party_individual_id = pi.party_individual_id
42
     AND p.meta_address_id = ma.meta_address_id
43
     AND p.meta_file_id = '{@meta_file_id}'
44

  
45
</xsql:query>
46

  
47
<xsql:query tag-case="lower" 
48
            rowset-element="" 
49
            row-element="" 
50
            id-attribute="">
51

  
52
  SELECT abstract FROM eml_dataset
53
   WHERE meta_file_id = '{@meta_file_id}'
54

  
55
</xsql:query>
56

  
57
<xsql:query tag-case="lower" 
58
            row-element="keyword_info" 
59
            rowset-element="" 
60
            id-attribute="">
61

  
62
  SELECT keyword, keyword_type, keyword_thesaurus
63
    FROM keyword_info
64
   WHERE meta_file_id = '{@meta_file_id}'
65

  
66
</xsql:query>
67

  
68
</eml-dataset>
0 69

  
xsqltest/xmltest2-xsql.xml
1
<?xml version="1.0"?>
2
<!--
3
  * xmltest2.xsql
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSQL (http://technet.oracle.com/tech/xml) document designed
14
  * to query a relational database and return the result as a well-formed
15
  * XML document.
16
-->
17
<page connection="demo" xmlns:xsql="urn:oracle-xsql">
18
<xsql:query>
19

  
20
  SELECT * FROM xmltest ORDER BY docid
21

  
22
</xsql:query>
23
</page>
0 24

  
xsqltest/eml-dataset1.xsql
1
<?xml version="1.0"?>
2
<!--
3
  * eml-dataset1.xsql
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSQL (http://technet.oracle.com/tech/xml) document designed
14
  * to query a relational database and return the result as a well-formed
15
  * XML document that contains the information necessary to transform the
16
  * document into the eml-dataset.dtd module of the Ecological Metadata
17
  * Language (EML)
18
-->
19
<?xml-stylesheet type="text/xsl" href="eml-dataset.xsl"?>
20
<eml-dataset connection="demo" xmlns:xsql="urn:oracle-xsql">
21

  
22
<xsql:query tag-case="lower" 
23
            rowset-element="" 
24
            row-element="" 
25
            id-attribute="">
26

  
27
  SELECT meta_file_id,dataset_id,title FROM eml_dataset
28
   WHERE meta_file_id = '{@meta_file_id}'
29

  
30
</xsql:query>
31

  
32
<xsql:query tag-case="lower" 
33
            row-element="originator" 
34
            rowset-element="" 
35
            id-attribute="">
36

  
37
  SELECT p.party_org, pi.salutation, pi.given_name, pi.surname, pi.jobtitle, 
38
         ma.address, ma.city, ma.admin_area, ma.postal_code, ma.country,
39
         ma.resource_url, ma.email, ma.work_phone, ma.home_phone, ma.fax,
40
         ma.tdd_phone 
41
    FROM party p, party_individual pi, meta_address ma
42
   WHERE p.party_individual_id = pi.party_individual_id
43
     AND p.meta_address_id = ma.meta_address_id
44
     AND p.meta_file_id = '{@meta_file_id}'
45

  
46
</xsql:query>
47

  
48
<xsql:query tag-case="lower" 
49
            rowset-element="" 
50
            row-element="" 
51
            id-attribute="">
52

  
53
  SELECT abstract FROM eml_dataset
54
   WHERE meta_file_id = '{@meta_file_id}'
55

  
56
</xsql:query>
57

  
58
<xsql:query tag-case="lower" 
59
            row-element="keyword_info" 
60
            rowset-element="" 
61
            id-attribute="">
62

  
63
  SELECT keyword, keyword_type, keyword_thesaurus
64
    FROM keyword_info
65
   WHERE meta_file_id = '{@meta_file_id}'
66

  
67
</xsql:query>
68

  
69
</eml-dataset>
0 70

  
xsqltest/eml-dataset-display.xsl
1
<?xml version="1.0"?>
2
<!--
3
  * eml-dataset-display.xsl
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the 
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  *
13
  * This is an XSLT (http://www.w3.org/TR/xslt) stylesheet designed to
14
  * convert an XML file that is valid with respect to the eml-dataset.dtd
15
  * module of the Ecological Metadata Language (EML) into an HTML format 
16
  * suitable for rendering with modern web browsers.
17
-->
18
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
19

  
20
  <xsl:output method="html"/>
21

  
22
  <xsl:template match="/">
23
    <html>
24
      <head>
25
	<link rel="stylesheet" type="text/css" href="./rowcol.css" />
26
      </head>
27
      <body class="eml-dataset">
28
	<center>
29
          <h1>Data set description</h1>
30
          <h3>Ecological Metadata Language</h3>
31
        </center>
32
        <xsl:apply-templates/>      
33

  
34
        <table width="100%">
35
        <tr><td class="rowodd">
36
        <b><xsl:text>Keywords:</xsl:text></b>
37
        </td></tr>
38
        <tr><td>
39
          <ul>
40
            <xsl:for-each select="//keyword_info/keyword">
41
              <li><xsl:value-of select="."/></li>
42
            </xsl:for-each>
43
          </ul>
44
        </td></tr>
45
        </table>
46
         
47

  
48
        <table width="100%">
49
        <tr><td class="rowodd">
50
        <b><xsl:text>Related Metadata and Data Files:</xsl:text></b>
51
        </td></tr>
52
        <tr><td>
53
        <ul>
54
          <xsl:for-each select="//relations">
55
            <li>
56
             <xsl:value-of select="@object"/>
57
             <xsl:text> </xsl:text>
58
             <xsl:value-of select="@relation"/>
59
             <xsl:text> </xsl:text>
60
             <xsl:value-of select="@target"/>
61
            </li>
62
          </xsl:for-each>
63
        </ul>
64
        </td></tr>
65
        </table>
66

  
67
      </body>
68
    </html>
69
  </xsl:template>
70

  
71
  <xsl:template match="meta_file_id">
72
    <table width="100%">
73
    <tr>
74
    <td class="rowodd"><b><xsl:text>Metadata File ID:</xsl:text></b></td>
75
    <td><xsl:value-of select="."/></td>
76
    </tr>
77
      <xsl:for-each select="//dataset_id|//title">
78
        <tr>
79
        <xsl:if test="name(.)='dataset_id'">
80
          <td class="rowodd"><b><xsl:text>Data set ID:</xsl:text></b></td>
81
        </xsl:if>
82
        <xsl:if test="name(.)='title'">
83
          <td class="rowodd"><b><xsl:text>Title:</xsl:text></b></td>
84
        </xsl:if>
85
        <td><xsl:value-of select="."/></td>
86
        </tr>
87
      </xsl:for-each>
88
    </table>
89

  
90
  </xsl:template>
91

  
92
  <xsl:template match="dataset_id"/>
93
  <xsl:template match="title"/>
94

  
95
  <xsl:template match="originator[1]">
96
      <table width="100%">
97
      <tr><td class="rowodd">
98
      <b><xsl:text>Data Set Owner(s):</xsl:text></b>
99
      </td></tr>
100
      </table>
101
  </xsl:template>
102

  
103
  <xsl:template match="party_org">
104
    <br><b><xsl:value-of select="."/></b></br>
105
  </xsl:template>
106

  
107
  <xsl:template match="party_individual">
108
    <br>
109
    <b>
110
       <xsl:value-of select="./salutation"/>
111
       <xsl:text> </xsl:text>
112
       <xsl:value-of select="./given_name"/>
113
       <xsl:text> </xsl:text>
114
       <xsl:value-of select="./surname"/>
115
    </b></br>
116
    <br><xsl:value-of select="./title"/></br>
117
  </xsl:template>
118

  
119
  <xsl:template match="meta_address">
120
    <table>
121
    <xsl:for-each select="./address">
122
      <tr>
123
      <td><xsl:value-of select="."/></td>
124
      </tr>
125
    </xsl:for-each>
126
    <tr>
127
    <td><xsl:value-of select="./city"/>
128
        <xsl:text>, </xsl:text>
129
        <xsl:value-of select="./admin_area"/>
130
        <xsl:text> </xsl:text>
131
        <xsl:value-of select="./postal_code"/>
132
    </td>
133
    </tr>
134
    <xsl:if test="./work_phone">
135
      <tr><td><xsl:text>Work: </xsl:text><xsl:value-of select="./work_phone"/>
136
       </td></tr>
137
    </xsl:if>
138
    <xsl:if test="./home_phone">
139
      <tr><td><xsl:text>Home: </xsl:text><xsl:value-of select="./home_phone"/>
140
       </td></tr>
141
    </xsl:if>
142
    <xsl:if test="./fax">
143
      <tr><td><xsl:text>Fax: </xsl:text><xsl:value-of select="./fax"/></td></tr>
144
    </xsl:if>
145
    <xsl:if test="./email">
146
      <tr><td><xsl:value-of select="./email"/></td></tr>
147
    </xsl:if>
148
    <xsl:if test="./resource_url">
149
      <tr><td><xsl:value-of select="./resource_url"/></td></tr>
150
    </xsl:if>
151
    </table>
152
  </xsl:template>
153

  
154
  <xsl:template match="abstract">
155
    <table width="100%">
156
    <tr>
157
    <td class="rowodd"><b><xsl:text>Abstract:</xsl:text></b></td>
158
    </tr>
159
    <tr>
160
    <td><xsl:value-of select="."/></td>
161
    </tr></table>
162
  </xsl:template>
163

  
164
  <xsl:template match="keyword_info"/>
165
  <xsl:template match="relations"/>
166

  
167
</xsl:stylesheet>
0 168

  
xsqltest/eml-dataset2.xsql
1
<?xml version="1.0"?>
2
<!--
3
  * eml-dataset2.xsql
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSQL (http://technet.oracle.com/tech/xml) document designed
14
  * to cause an XSLT (http://www.w3.org/TR/xslt) stylesheet transformation
15
  * of the results of another XSLT query
16
-->
17
<?xml-stylesheet type="text/xsl" href="eml-dataset-display.xsl"?>
18
<xsql:include-xsql 
19
      href="eml-dataset1.xsql?meta_file_id=NCEAS-1998-2244-Dist-Dataset" 
20
      xmlns:xsql="urn:oracle-xsql"/>
0 21

  
xsqltest/xmltest2.xsql
1
<?xml version="1.0"?>
2
<!--
3
  * xmltest2.xsql
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  * 
13
  * This is an XSQL (http://technet.oracle.com/tech/xml) document designed
14
  * to query a relational database and return the result as a well-formed
15
  * XML document.
16
-->
17
<?xml-stylesheet type="text/xsl" href="rowcol.xsl"?>
18
<page connection="demo" xmlns:xsql="urn:oracle-xsql">
19
<xsql:query>
20

  
21
  SELECT * FROM xmltest ORDER BY docid
22

  
23
</xsql:query>
24
</page>
0 25

  
xsqltest/index.html
1
<!--
2
  * index.html
3
  *
4
  *      Authors: Matt Jones
5
  *    Copyright: 2000 Regents of the University of California and the
6
  *               National Center for Ecological Analysis and Synthesis
7
  *  For Details: http://www.nceas.ucsb.edu/
8
  *      Created: 2000 April 5
9
  *      Version: 0.01
10
  *    File Info: '$Id$'
11
  * 
12
  * This is an HTML document for displaying examples of the use of 
13
  * Oracle XML tools
14
-->
15
  <HTML>
16
  <HEAD>
17
  <TITLE>XSL Transformation examples</TITLE>
18
  </HEAD> 
19
  <FRAMESET ROWS="*" FRAMEBORDER=0 BORDER=0>
20

  
21
    <FRAMESET COLS="250,*"  FRAMEBORDER=0 BORDER=0>
22
    
23
    <FRAME SRC="contents.html" BORDER=0 NAME="left">
24

  
25
    <FRAME SRC="xmltest2.xsql" BORDER=0 NAME="right">
26

  
27
    </FRAMESET>
28
  </FRAMESET>
0 29

  
xsqltest/rowcol.xsl
1
<?xml version="1.0"?>
2
<!--
3
  * rowcol.xsl
4
  *
5
  * This is an XSLT (http://www.w3.org/TR/xslt) stylesheet designed to
6
  * convert an XML file that is the result of a SQL query using Oracle's
7
  * XSQL tool to HTML format using a generic tabular display. Cascading
8
  * Style Sheets (CSS) are used to create some styling effects.
9
-->
10
<!--
11
| $Author$
12
| $Date$
13
| $Source$
14
| $Revision$
15
+-->
16
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
17

  
18

  
19
  <xsl:template match="/">
20
    <html>
21
      <head>
22
	<link rel="stylesheet" type="text/css" href="./rowcol.css" />
23
      </head>
24
      <body class="page">
25
	<center><h1>XSL Transformed View</h1></center>
26
        <xsl:apply-templates/>      
27
      </body>
28
    </html>
29
  </xsl:template>
30

  
31
    <xsl:template match="ROWSET">
32
      <center>
33
      <table border="0" cellpadding="4">
34
      <xsl:choose>
35
        <xsl:when test="ROW">
36
	  <xsl:for-each select="ROW[1]">
37
	    <tr>
38
	      <xsl:for-each select="*[not(starts-with(name(.),'H_'))]">
39
		<th align="left">
40
		  <xsl:attribute name="class">
41
		    <xsl:choose>
42
		      <xsl:when test="position() mod 2 = 1">colodd</xsl:when>
43
		      <xsl:when test="position() mod 2 = 0">coleven</xsl:when>
44
		    </xsl:choose>
45
		  </xsl:attribute>
46
		  <xsl:value-of select="name(.)"/>
47
		</th>
48
	      </xsl:for-each>
49
	    </tr>
50
	  </xsl:for-each>
51
	  <xsl:apply-templates/>
52
        </xsl:when>
53
        <xsl:otherwise>
54
          <tr><td>No Matches</td></tr> 
55
        </xsl:otherwise>
56
      </xsl:choose>
57
      </table>
58
      </center>
59
    </xsl:template>
60

  
61
    <xsl:template match="ROW">
62
        <tr>
63
          <xsl:attribute name="class">
64
            <xsl:choose>
65
              <xsl:when test="position() mod 2 = 1">rowodd</xsl:when>
66
              <xsl:when test="position() mod 2 = 0">roweven</xsl:when>
67
            </xsl:choose>
68
          </xsl:attribute>
69
          <xsl:for-each select="*[not(starts-with(name(.),'H_'))]">
70
            <td>
71
	      <xsl:attribute name="class">
72
		<xsl:choose>
73
		  <xsl:when test="position() mod 2 = 1">colodd</xsl:when>
74
		  <xsl:when test="position() mod 2 = 0">coleven</xsl:when>
75
		</xsl:choose>
76
	      </xsl:attribute>
77
              <xsl:apply-templates select='.'/>
78
            </td>
79
          </xsl:for-each>
80
        </tr>
81
  </xsl:template>
82

  
83
</xsl:stylesheet>
0 84

  
xsqltest/rowcol.css
1
 .page    {font-family: Tahoma, sans-serif; background-color:white}
2
 .eml-dataset    {font-family: Tahoma, sans-serif; background-color:white}
3
 .rowodd  {background-color: #DDDDDD; color: black; vertical-align: top}
4
 .roweven {background-color: #F8F8F8; color: black; vertical-align: top}
5
 .coleven {}
6
 .colodd  {}
7
 .shaded  {background-color: #DDDDDD; color: black}
0 8

  
xsqltest/xmltest.sql
1
/**
2
 *        Name: xmltest.sql
3
 *     Purpose: create a table for storing test data in oracle
4
 * Institution: National Center for Ecological Analysis and Synthesis
5
 *   Copyright: 2000
6
 *     Authors: Matt Jones
7
 *
8
 *     Version: '$Id$'
9
 */
10

  
11
CREATE TABLE xmltest (
12
	docid		NUMBER(10) PRIMARY KEY,
13
	lastname	VARCHAR2(25),
14
	firstname	VARCHAR2(25)
15
);
0 16

  
lib/style/eml-dataset-display.xsl
1
<?xml version="1.0"?>
2
<!--
3
  * eml-dataset-display.xsl
4
  *
5
  *      Authors: Matt Jones
6
  *    Copyright: 2000 Regents of the University of California and the 
7
  *               National Center for Ecological Analysis and Synthesis
8
  *  For Details: http://www.nceas.ucsb.edu/
9
  *      Created: 2000 April 5
10
  *      Version: 0.01
11
  *    File Info: '$Id$'
12
  *
13
  * This is an XSLT (http://www.w3.org/TR/xslt) stylesheet designed to
14
  * convert an XML file that is valid with respect to the eml-dataset.dtd
15
  * module of the Ecological Metadata Language (EML) into an HTML format 
16
  * suitable for rendering with modern web browsers.
17
-->
18
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
19

  
20
  <xsl:output method="html"/>
21

  
22
  <xsl:template match="/">
23
    <html>
24
      <head>
25
	<link rel="stylesheet" type="text/css" href="./rowcol.css" />
26
      </head>
27
      <body class="eml-dataset">
28
	<center>
29
          <h1>Data set description</h1>
30
          <h3>Ecological Metadata Language</h3>
31
        </center>
32
        <xsl:apply-templates/>      
33

  
34
        <table width="100%">
35
        <tr><td class="rowodd">
36
        <b><xsl:text>Keywords:</xsl:text></b>
37
        </td></tr>
38
        <tr><td>
39
          <ul>
40
            <xsl:for-each select="//keyword_info/keyword">
41
              <li><xsl:value-of select="."/></li>
42
            </xsl:for-each>
43
          </ul>
44
        </td></tr>
45
        </table>
46
         
47

  
48
        <table width="100%">
49
        <tr><td class="rowodd">
50
        <b><xsl:text>Related Metadata and Data Files:</xsl:text></b>
51
        </td></tr>
52
        <tr><td>
53
        <ul>
54
          <xsl:for-each select="//relations">
55
            <li>
56
             <xsl:value-of select="@object"/>
57
             <xsl:text> </xsl:text>
58
             <xsl:value-of select="@relation"/>
59
             <xsl:text> </xsl:text>
60
             <xsl:value-of select="@target"/>
61
            </li>
62
          </xsl:for-each>
63
        </ul>
64
        </td></tr>
65
        </table>
66

  
67
      </body>
68
    </html>
69
  </xsl:template>
70

  
71
  <xsl:template match="meta_file_id">
72
    <table width="100%">
73
    <tr>
74
    <td class="rowodd"><b><xsl:text>Metadata File ID:</xsl:text></b></td>
75
    <td><xsl:value-of select="."/></td>
76
    </tr>
77
      <xsl:for-each select="//dataset_id|//title">
78
        <tr>
79
        <xsl:if test="name(.)='dataset_id'">
80
          <td class="rowodd"><b><xsl:text>Data set ID:</xsl:text></b></td>
81
        </xsl:if>
82
        <xsl:if test="name(.)='title'">
83
          <td class="rowodd"><b><xsl:text>Title:</xsl:text></b></td>
84
        </xsl:if>
85
        <td><xsl:value-of select="."/></td>
86
        </tr>
87
      </xsl:for-each>
88
    </table>
89

  
90
  </xsl:template>
91

  
92
  <xsl:template match="dataset_id"/>
93
  <xsl:template match="title"/>
94

  
95
  <xsl:template match="originator[1]">
96
      <table width="100%">
97
      <tr><td class="rowodd">
98
      <b><xsl:text>Data Set Owner(s):</xsl:text></b>
99
      </td></tr>
100
      </table>
101
  </xsl:template>
102

  
103
  <xsl:template match="party_org">
104
    <br><b><xsl:value-of select="."/></b></br>
105
  </xsl:template>
106

  
107
  <xsl:template match="party_individual">
108
    <br>
109
    <b>
110
       <xsl:value-of select="./salutation"/>
111
       <xsl:text> </xsl:text>
112
       <xsl:value-of select="./given_name"/>
113
       <xsl:text> </xsl:text>
114
       <xsl:value-of select="./surname"/>
115
    </b></br>
116
    <br><xsl:value-of select="./title"/></br>
117
  </xsl:template>
118

  
119
  <xsl:template match="meta_address">
120
    <table>
121
    <xsl:for-each select="./address">
122
      <tr>
123
      <td><xsl:value-of select="."/></td>
124
      </tr>
125
    </xsl:for-each>
126
    <tr>
127
    <td><xsl:value-of select="./city"/>
128
        <xsl:text>, </xsl:text>
129
        <xsl:value-of select="./admin_area"/>
130
        <xsl:text> </xsl:text>
131
        <xsl:value-of select="./postal_code"/>
132
    </td>
133
    </tr>
134
    <xsl:if test="./work_phone">
135
      <tr><td><xsl:text>Work: </xsl:text><xsl:value-of select="./work_phone"/>
136
       </td></tr>
137
    </xsl:if>
138
    <xsl:if test="./home_phone">
139
      <tr><td><xsl:text>Home: </xsl:text><xsl:value-of select="./home_phone"/>
140
       </td></tr>
141
    </xsl:if>
142
    <xsl:if test="./fax">
143
      <tr><td><xsl:text>Fax: </xsl:text><xsl:value-of select="./fax"/></td></tr>
144
    </xsl:if>
145
    <xsl:if test="./email">
146
      <tr><td><xsl:value-of select="./email"/></td></tr>
147
    </xsl:if>
148
    <xsl:if test="./resource_url">
149
      <tr><td><xsl:value-of select="./resource_url"/></td></tr>
150
    </xsl:if>
151
    </table>
152
  </xsl:template>
153

  
154
  <xsl:template match="abstract">
155
    <table width="100%">
156
    <tr>
157
    <td class="rowodd"><b><xsl:text>Abstract:</xsl:text></b></td>
158
    </tr>
159
    <tr>
160
    <td><xsl:value-of select="."/></td>
161
    </tr></table>
162
  </xsl:template>
163

  
164
  <xsl:template match="keyword_info"/>
165
  <xsl:template match="relations"/>
166

  
167
</xsl:stylesheet>
0 168

  

Also available in: Unified diff