XML - Managing Data Exchange/The many-to-many relationship/Answers
Many-to-Many Chapter => The Many-to-Many Relationship
Many-to-Many Exercises => Exercises
1) Movie Collection
editUse the following data model:
- a. Using the IDREF method, create an XML schema to describe the illustrated data model. Include all of the attributes listed in the data model.
- b. Create an XML document that includes at least two movies and two cast members per movie.
- c. Create a simple XML style sheet to present the information in HTML format. No tables or CSS are necessary.
the Schema
edit<?xml version="1.0" encoding="UTF-8"?> <!-- Document : movies.xsd Created on : February 6, 2006 Author : Christina Serrano Description: XML schema describing structure of movie collection --> <xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" elementFormDefault="unqualified"> <xsd:element name="movieCollection"> <xsd:complexType> <xsd:sequence> <xsd:element name="movie" type="movieDetails" minOccurs="1" maxOccurs="unbounded"/> <xsd:element name="castMember" type="castDetails" minOccurs="1" maxOccurs="unbounded"/> </xsd:sequence> </xsd:complexType> </xsd:element> <xsd:complexType name="movieDetails"> <xsd:sequence> <xsd:element name="movieTitle" type="xsd:string"/> <xsd:element name="movieSynopsis" type="xsd:string"/> <xsd:element name="role" type="roleDetails" minOccurs="1" maxOccurs="unbounded"/> </xsd:sequence> </xsd:complexType> <xsd:complexType name="roleDetails"> <xsd:sequence> <xsd:element name="roleIDREF" type="xsd:IDREF"/> <xsd:element name="roleType" type="xsd:string"/> </xsd:sequence> </xsd:complexType> <xsd:complexType name="castDetails"> <xsd:sequence> <xsd:element name="castMemberID" type="xsd:ID"/> <xsd:element name="castFirstName" type="xsd:string"/> <xsd:element name="castLastName" type="xsd:string"/> <xsd:element name="castSSN" type="ssnType" minOccurs="0"/> <xsd:element name="castGender" type="genderType"/> </xsd:sequence> </xsd:complexType> <xsd:simpleType name="ssnType"> <xsd:restriction base="xsd:string"> <xsd:pattern value="\d{3}-\d{2}-\d{4}"/> </xsd:restriction> </xsd:simpleType> <xsd:simpleType name="genderType"> <xsd:restriction base="xsd:string"> <xsd:enumeration value="male"/> <xsd:enumeration value="female"/> </xsd:restriction> </xsd:simpleType> </xsd:schema>
the Document
edit<?xml version="1.0" encoding="UTF-8"?> <?xml-stylesheet href="movies.xsl" type="text/xsl" media="screen"?> <!-- Document : movies.xml Created on : February 6, 2006 Author : Christina Serrano Description: XML document describing movie collection --> <movieCollection xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="movies.xsd"> <movie> <movieTitle>City of God</movieTitle> <movieSynopsis> Youth gangs took over the slums of Rio de Janiero during the 1960s and didn't relinquish their stronghold until the mid-1980s. Only a sucker wouldn't have turned to crime and this is exactly how naive teen Rocket views himself. Rocket shoots all of the action with his weapon of choice, a camera. </movieSynopsis> <role> <roleIDREF>ar1</roleIDREF> <roleType>Lead Actor</roleType> </role> <role> <roleIDREF>lf1</roleIDREF> <roleType>Lead Actor</roleType> </role> <role> <roleIDREF>kf1</roleIDREF> <roleType>Lead Actress</roleType> </role> </movie> <movie> <movieTitle>Hotel Rwanda</movieTitle> <movieSynopsis> Paul Rusesabagina, the manager of a European-owned hotel in Rwanda, created a secret refugee camp for the Tutsi people during the brutal genocide committed against them by the Hutu people in 1994. His efforts helped to save 1200 lives out of close to a million who were killed. </movieSynopsis> <role> <roleIDREF>dc1</roleIDREF> <roleType>Lead Actor</roleType> </role> <role> <roleIDREF>nn1</roleIDREF> <roleType>Supporting Actor</roleType> </role> <role> <roleIDREF>so1</roleIDREF> <roleType>Lead Actress</roleType> </role> </movie> <movie> <movieTitle>Dodgeball</movieTitle> <movieSynopsis> The story's protagonist, Peter LaFleur, is a charismatic underachiever and proprietor of a rundown gym called Average Joe's. Peter's humble gym catches the eye of White Goodman, the power-mullet-sporting, Fu-Manchu-d, egomaniacal owner of Globo Gym, a gleaming monolith of fitness. White intends to take over Average Joe's, and Peter's non-existent bookkeeping is making it all too easy for him. The only way Peter can save Average Joe's is a showdown dodgeball competition against Globo Gym. </movieSynopsis> <role> <roleIDREF>bs1</roleIDREF> <roleType>Lead Actor</roleType> </role> <role> <roleIDREF>ct1</roleIDREF> <roleType>Lead Actress</roleType> </role> <role> <roleIDREF>vv1</roleIDREF> <roleType>Lead Actor</roleType> </role> </movie> <movie> <movieTitle>Meet the Parents</movieTitle> <movieSynopsis> Greg Focker is head over heels in love with his girlfriend Pam, and is ready to pop the big question. When his attempt to propose is thwarted by a phone call with the news that Pam's younger sister is getting married, Greg realizes that the key to Pam's hand in marriage lies with her formidable father. </movieSynopsis> <role> <roleIDREF>bs1</roleIDREF> <roleType>Lead Actor</roleType> </role> <role> <roleIDREF>tp1</roleIDREF> <roleType>Lead Actress</roleType> </role> <role> <roleIDREF>rd1</roleIDREF> <roleType>Lead Actor</roleType> </role> </movie> <castMember> <castMemberID>ar1</castMemberID> <castFirstName>Alexandre</castFirstName> <castLastName>Rodrigues</castLastName> <castSSN>867-34-2949</castSSN> <castGender>male</castGender> </castMember> <castMember> <castMemberID>lf1</castMemberID> <castFirstName>Leandro</castFirstName> <castLastName>Firmino da Hora</castLastName> <castSSN>839-59-8765</castSSN> <castGender>male</castGender> </castMember> <castMember> <castMemberID>kf1</castMemberID> <castFirstName>Karina</castFirstName> <castLastName>Falcao</castLastName> <castSSN>987-34-2958</castSSN> <castGender>female</castGender> </castMember> <castMember> <castMemberID>dc1</castMemberID> <castFirstName>Don</castFirstName> <castLastName>Cheadle</castLastName> <castSSN>849-39-4439</castSSN> <castGender>male</castGender> </castMember> <castMember> <castMemberID>nn1</castMemberID> <castFirstName>Nick</castFirstName> <castLastName>Nolte</castLastName> <castSSN>233-56-4309</castSSN> <castGender>male</castGender> </castMember> <castMember> <castMemberID>so1</castMemberID> <castFirstName>Sophie</castFirstName> <castLastName>Okonedo</castLastName> <castSSN>993-23-4958</castSSN> <castGender>female</castGender> </castMember> <castMember> <castMemberID>rd1</castMemberID> <castFirstName>Robert</castFirstName> <castLastName>De Niro</castLastName> <castSSN>489-32-5984</castSSN> <castGender>male</castGender> </castMember> <castMember> <castMemberID>bs1</castMemberID> <castFirstName>Ben</castFirstName> <castLastName>Stiller</castLastName> <castSSN>590-59-2774</castSSN> <castGender>male</castGender> </castMember> <castMember> <castMemberID>tp1</castMemberID> <castFirstName>Teri</castFirstName> <castLastName>Polo</castLastName> <castSSN>099-37-8765</castSSN> <castGender>female</castGender> </castMember> <castMember> <castMemberID>vv1</castMemberID> <castFirstName>Vince</castFirstName> <castLastName>Vaughn</castLastName> <castSSN>383-56-2095</castSSN> <castGender>male</castGender> </castMember> <castMember> <castMemberID>ct1</castMemberID> <castFirstName>Christine</castFirstName> <castLastName>Taylor</castLastName> <castSSN>309-49-4005</castSSN> <castGender>female</castGender> </castMember> </movieCollection>
the Stylesheet
edit<?xml version="1.0" encoding="UTF-8"?> <!-- Document : movies.xsl Created on : February 6, 2006 Author : Christina Serrano Description: XML stylesheet to format movie collection data --> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:key name="castList" match="castMember" use="castMemberID"/> <xsl:output method="html"/> <xsl:template match="/"> <HTML> <HEAD> <TITLE>Movie Collection</TITLE> </HEAD> <BODY> <H2>Movie Collection</H2> <xsl:apply-templates select="movieCollection"/> </BODY> </HTML> </xsl:template> <xsl:template match="movieCollection"> <xsl:for-each select="movie"> <HR/> <BR/> <b><xsl:text>Movie Title: </xsl:text></b> <xsl:value-of select="movieTitle"/> <BR/> <BR/> <b><xsl:text>Movie Synopsis: </xsl:text></b> <xsl:value-of select="movieSynopsis"/> <BR/> <BR/> <b><xsl:text>Cast: </xsl:text></b> <BR/> <xsl:for-each select="role"> <xsl:value-of select="key('castList',roleIDREF)/castFirstName"/> <xsl:text> </xsl:text> <xsl:value-of select="key('castList',roleIDREF)/castLastName"/> <xsl:text>, </xsl:text> <xsl:value-of select="roleType"/> <BR/> <xsl:value-of select="key('castList',roleIDREF)/castGender"/> <xsl:text>, </xsl:text> <xsl:value-of select="key('castList',roleIDREF)/castSSN"/> <BR/> <BR/> </xsl:for-each> </xsl:for-each> </xsl:template> </xsl:stylesheet>
2) Student/Class Directory
edit- a. Every class at a school can have many students, and each student can be registered to more than one class at a time. Create an XML schema to capture this many-to-many relationship. Be sure to include the class name, capacity, building number, building name, and room number. Also include the student first/last name separately and his or her grade for the class.
- b. Using the XML schema created in part a, create an XML document and an XML stylesheet. You can make up your own data, but be sure to use at least three students for each class.
the Schema
edit<?xml version="1.0" encoding="UTF-8"?> <xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" elementFormDefault="unqualified"> <xsd:element name="classDirectory"> <xsd:complexType> <xsd:sequence> <xsd:element name="class" type="classDetails" maxOccurs="unbounded"/> <xsd:element name="studentRef" type="studentID" maxOccurs="unbounded"/> </xsd:sequence> </xsd:complexType> </xsd:element> <xsd:complexType name="classDetails"> <xsd:sequence> <xsd:element name="className" type="xsd:string"/> <xsd:element name="classLocation" type="locationDetails"/> <xsd:element name="classCapacity" type="xsd:integer"/> <xsd:element name="student" type="studentValue" maxOccurs="unbounded"/> </xsd:sequence> </xsd:complexType> <xsd:complexType name="locationDetails"> <xsd:sequence> <xsd:element name="classRoomNumber" type="xsd:string"/> <xsd:element name="classBuildingName" type="xsd:string"/> </xsd:sequence> </xsd:complexType> <xsd:complexType name="studentValue"> <xsd:sequence> <xsd:element name="studentIDREF" type="xsd:IDREF"/> <xsd:element name="studentGrade" type="xsd:string"/> </xsd:sequence> </xsd:complexType> <xsd:complexType name="studentID"> <xsd:sequence> <xsd:element name="studentIDValue" type="xsd:ID"/> <xsd:element name="studentFirstName" type="xsd:string"/> <xsd:element name="studentLastName" type="xsd:string"/> </xsd:sequence> </xsd:complexType> </xsd:schema>
the Document
edit<?xml version="1.0" encoding="UTF-8"?> <classDirectory xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:noNamespaceSchemaLocation='unidirectory6.xsd'> <class> <className>MATH 2200</className> <classLocation> <classRoomNumber>206B</classRoomNumber> <classBuildingName>Boyd</classBuildingName> </classLocation> <classCapacity>30</classCapacity> <student> <studentIDREF>a1</studentIDREF> <studentGrade>80</studentGrade> </student> <student> <studentIDREF>a2</studentIDREF> <studentGrade>98</studentGrade> </student> <student> <studentIDREF>a3</studentIDREF> <studentGrade>76</studentGrade> </student> </class> <class> <className>JOUR 3310</className> <classLocation> <classRoomNumber>102</classRoomNumber> <classBuildingName>MLC</classBuildingName> </classLocation> <classCapacity>150</classCapacity> <student> <studentIDREF>a4</studentIDREF> <studentGrade>80</studentGrade> </student> <student> <studentIDREF>a1</studentIDREF> <studentGrade>98</studentGrade> </student> <student> <studentIDREF>a5</studentIDREF> <studentGrade>76</studentGrade> </student> </class> <studentRef> <studentIDValue>a1</studentIDValue> <studentFirstName>John</studentFirstName> <studentLastName>Smith</studentLastName> </studentRef> <studentRef> <studentIDValue>a2</studentIDValue> <studentFirstName>Katie</studentFirstName> <studentLastName>Black</studentLastName> </studentRef> <studentRef> <studentIDValue>a3</studentIDValue> <studentFirstName>Charles</studentFirstName> <studentLastName>Fisher</studentLastName> </studentRef> <studentRef> <studentIDValue>a4</studentIDValue> <studentFirstName>Sarah</studentFirstName> <studentLastName>Dawson</studentLastName> </studentRef> <studentRef> <studentIDValue>a5</studentIDValue> <studentFirstName>Alex</studentFirstName> <studentLastName>Patton</studentLastName> </studentRef> </classDirectory>
the Stylesheet
edit<?xml version="1.0" encoding="UTF-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:key name="sList" match="studentRef" use="studentIDValue"/> <xsl:output method="html"/> <xsl:template match="/"> <html> <head> <title>Class Directory</title> </head> <body> <xsl:apply-templates select="classDirectory"/> </body> </html> </xsl:template> <xsl:template match="classDirectory"> <xsl:for-each select="class"> <b><xsl:value-of select="className"/></b> <br/> <xsl:for-each select="student"> <xsl:sort select="key('sList',studentIDREF)/studentLastName"/> <xsl:value-of select="key('sList',studentIDREF)/studentLastName"/> <xsl:text>, </xsl:text> <xsl:value-of select="key('sList',studentIDREF)/studentFirstName"/> <xsl:text>: </xsl:text> <xsl:value-of select="studentGrade"/> <BR/> </xsl:for-each> <br/> <br/> </xsl:for-each> <br/> </xsl:template> </xsl:stylesheet>
Many-to-Many Chapter => The Many-to-Many Relationship
Many-to-Many Exercises => Exercises