advertisement
javaboutique
Search Tips
Articles  |   Tutorials  |   Reviews  |   Tools  |   by Category  |   by Date  |   by Name  |   Submit  |   Source  |   Forums  |  
javaboutique
Browse DevX


Partners & Affiliates











advertisement


Reviews :

Mapping Java Objects to a Database with Castor-JDO:

Handling many-to-many relations

Lets' add a many-to-many relation to the object model by introducing the Actor object:

Again we'll go through the steps of adding this relation to the Java model, the database, and the Castor setup.

A. Java classes

The Actor class looks like this:

package hansen.playground;

import java.util.*;

public class Actor {

  private int id;
  private String name;
  private Collection movies = new ArrayList();
  
  public Actor() {}
  public Actor(int id, String name) { this.id = id;
                                      this.name = name;}
  
  public int getId() { return id; }
  public void setId(int id) { this.id = id; }

  public String getName() { return name; }
  public void setName(String name) { this.name = name; }

  public Collection getMovies() { return movies; }
  public void setMovies(Collection movies) { 
    this.movies = movies; 
  }
  
  public void addMovie(Movie movie) {
    movies.add(movie);
  }
  
}

- Listing 6: The Actor class -

The addMovie method simplifies adding a movie to an actor.  

In Movie we must add a Collection for the actors:

private Collection actors = new ArrayList();
public Collection getActors() { return actors; }
public void setActors(Collection actors) { 
  this.actors = actors; 
}

public void addActor(Actor actor) {
  actors.add(actor);
} 

B. Database tables 

Create the actor table:

CREATE TABLE actor (
  id int NOT NULL,
  name varchar(100),
  PRIMARY KEY (id)
) 

A many-to-many relation is normally handled by making a new table, the bridge table, that holds the two foreign keys for the two tables. For this purpose we therefore create the actor_movie table:

  CREATE TABLE actor_movie (
  id_actor int NOT NULL,
  id_movie int NOT NULL,
  PRIMARY KEY  (id_actor,id_movie)
) 

C. The mappings file 

Modify the mapping.xml file: 

<class name="hansen.playground.Movie" identity="id">
    <map-to table="movie" />
    . . .
    <field name="actors" type="hansen.playground.Actor" collection="collection">
      <sql name="id_actor" many-table="actor_movie" many-key="id_movie" />
    </field>
  </class>

  <class name="hansen.playground.Actor" identity="id">
    <map-to table="actor" />
    <field name="id" type="integer">
      <sql name="id" type="integer"/>
    </field>
    <field name="name" type="string">
      <sql name="name" type="varchar" />
    </field>
    <field name="movies" type="hansen.playground.Movie" collection="collection">
      <sql name="id_movie" many-table="actor_movie" many-key="id_actor" />
    </field>
  </class>

As you can see the many-to-many case is handled by three attributes in the sql element:

  • many-table: the name of the bridge table
  • name: the field in the bridge table that has the key to the other object
  • many-key: as for the "one-to-many" situation, this is the name of the field that has the key to ourselves  

D. Test the setup

Let's assume that we now have these three movies in the movie table:

id
id_media
title
11
1
The Matrix
12
1
Lord of the Rings
13
2
Chain Reaction

How to Add Java Applets to Your Site

New on the Java Boutique:

New Review:

Time Management Made Easy with the Quartz Enterprise Job Scheduler
Why not just use the Java timer API? This open source scheduling API boasts simplicity, ease-of-integration, a well-rounded feature set, and it's free!

New Applet:

Reverse Complement
Reverse Complement is a simple applet that converts DNA or RNA sequences into three useful formats.

Elsewhere on internet.com:

WebDeveloper Java
Lots of Java information on webdeveloper.com

WDVL Java
Thorough Java resource at the Web Developer's Virtual Library.

ScriptSearch Java
Hundreds of free Java code files to download.

jGuru: Your View of the Java Universe
Customizable portal with online training, FAQs, regular news updates, and tutorials.

 Microsoft Visual Studio 2010 Showcase
 Avaya Developer Showcase
 MSDN Spotlight
 PHP for Windows Showcase
XML error: undefined entity at line 39
advertisement
Receive Articles via our XML/RSS feed
Receive Articles via our XML/RSS feed

JavaBytes
Internet Cyclone
This powerful, easy-to-use, internet optimizer is for Windows 95, 98, ME, NT, 2000 and XP. It's designed to automatically optimize your Windows settings, boosting your Internet connection up to 200%.

Windows 7: From Beta to Final Code in One Year
Google Shows Off Chrome OS, Releases Source
Microsoft Shows Off Silverlight 4, IE9 Plans
Metasploit Expands Vulnerability Test Framework
HyperCard Reborn?
Fedora 12 Takes Aim at Linux Networking
Top Supercomputer Nearly Doubles in Speed
Fedora 12 Linux Tackles Virtualization
Apple Gives iPhone Developers App Status Tracker
Novell Sets OpenSUSE 11.2 Free

Creating Custom Export Filters for StarOffice with XSLT
WPF Wonders: Using DataTemplates
Crystal Reports Family Offers Options for Developers
Avaya Aura Session Manager video
Avaya Aura Overview video
Exploring HTML 5's Audio/Video Multimedia Support
Overriding Virtual Functions? Use C++0x Attributes to Avoid Bugs.
Understanding the Cloud Computing Security Vulnerabilities
Cisco and IBM Target a Greener World
Upgrade to Visual Studio 2010 with the Ultimate Offer

Advertising Info  |   Member Services  |   Contact Us  |   Help  |   Feedback  |   Site Map  |   Network Map  |   About

internet.commediabistro.comJusttechjobs.comGraphics.com

Search:

WebMediaBrands Corporate Info

Legal Notices, Licensing, Permissions, Privacy Policy.
Advertise | Newsletters | Shopping | E-mail Offers | Freelance Jobs