File APIs for Java Developers
Manipulate DOC, XLS, PPT, PDF and many others from your application.
The moose likes Object Relational Mapping and the fly likes Saving Associated objects Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login
JavaRanch » Java Forums » Databases » Object Relational Mapping
Bookmark "Saving Associated objects" Watch "Saving Associated objects" New topic

Saving Associated objects

Sunit Dev

Joined: Aug 05, 2006
Posts: 1
Hello All,

I have one very basic question to ask.

I have 2 tables

Book [Parent table]
Chapter [Child table]

There is a one-to-many relationship between these 2 tables. 1 book has many chapters. Book objects holds collection of Chapter objects.

I am using Spring and Hibernate in my application. We designed our DAO layer to keep the persistence logic separate from application.

Requirement is that, user will send the books and chapters information 2 one method. This method is in Spring manager class. Now we have to store information in both of these tables, as these objects are associated.

My confusion is how to store these 2 objects in 2 different tables with a single save.

As I am getting information about these 2 objects in Spring layer I can't open Hibernate session there as well as not clear either to pass populated objects to DAO layer, which will open the session and will store these objects one by one.

I know this is a basic problem, please guide me.

pascal betz
Ranch Hand

Joined: Jun 19, 2001
Posts: 547
you need to either save the objects "manually" in the same transaction:

or specify an appropriate cascade level on the relationship (see hibernate docu)

Ghulam Rashid
Ranch Hand

Joined: Jan 14, 2002
Posts: 278
There are variuos ways to accomplish it. One approach is -

Book book = new Book();
book.setBookname("Hibernate in Action");

Chapter chapterOne = new Chapter();
chapterOne.setChaptername("Introduction to Hibernate");

Chapter chapterTwo = new Chapter();
chapterOne.setChaptername("Understanding Persistence");

Set chapterSet = new HashSet();


In chapter.hbm.xml you have define <many-to-one> and book.hbm.xml you have define
<set name="chapters" .....>
<one-to-many class="Chapter" ../>

Similary you have to write POJO.

I hope this will help.
I agree. Here's the link:
subject: Saving Associated objects
It's not a secret anymore!