Solved

understanding  hibernate mapping tutorial

Posted on 2009-05-17
3
447 Views
Last Modified: 2013-12-29
Here i have attached a  hibernate  Event.hbm.xml file.

I have a query here .

note , we have an entry
<id name="id" column="uid" type="long" unsaved-value="null">  

and also we have entry...

<set name="speakers" cascade="all">
            <key column="event_id"/>
            <one-to-many class="Speaker"/>
        </set>


does that mean hibernate will automatically understand  "id" column  in Event table is a foreign key  "event_id"  column in Speaker table ?

How hibernate will understand that ?i don't see any foreign key tag in the mapping file ....so i am bit confused at this part.

I am not sure , how hibernate will relate these two column .  because i think whenever a value say "1" is saved in "id" field , there will also "1" be saved in event_id column because of this mapping file....right ?



<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 2.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">
 
<hibernate-mapping>
    <class name="Event" table="events">
        <id name="id" column="uid" type="long" unsaved-value="null">
            <generator class="increment"/>
        </id>
        <property name="name" type="string" length="100"/>
        <property name="startDate" column="start_date"
                  type="date"/>
        <property name="duration" type="integer"/>
        <many-to-one name="location" column="location_id" class="Location"/>
        <set name="speakers" cascade="all">
            <key column="event_id"/>
            <one-to-many class="Speaker"/>
        </set>
        <set name="attendees" cascade="all">
            <key column="event_id"/>
            <one-to-many class="Attendee"/>
        </set>
    </class>
</hibernate-mapping>

Open in new window

0
Comment
Question by:cofactor
  • 2
3 Comments
 
LVL 92

Expert Comment

by:objects
ID: 24409058
>            

that specifies which column is the foreign key for a Speaker
And as it is specified in the Event mapping then it relates to the Event class

0
 

Author Comment

by:cofactor
ID: 24409163
the DDL has been given as below in the tutorial

create table events (uid int ,
name varchar,
start_date date,
duration integer,
location_id int)


create table speakers (uid int,
firstName varchar,
lastName varchar,
event_id int)


but  there is no FK constraint put in this  DDL  .....shall  we need to put constraints here ?
0
 
LVL 92

Accepted Solution

by:
objects earned 125 total points
ID: 24409167
up to you, not necessary to make it work.
0

Featured Post

Use Case: Protecting a Hybrid Cloud Infrastructure

Microsoft Azure is rapidly becoming the norm in dynamic IT environments. This document describes the challenges that organizations face when protecting data in a hybrid cloud IT environment and presents a use case to demonstrate how Acronis Backup protects all data.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

After being asked a question last year, I went into one of my moods where I did some research and code just for the fun and learning of it all.  Subsequently, from this journey, I put together this article on "Range Searching Using Visual Basic.NET …
Introduction This article is the second of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article covers the basic installation and configuration of the test automation tools used by…
Viewers learn about the “for” loop and how it works in Java. By comparing it to the while loop learned before, viewers can make the transition easily. You will learn about the formatting of the for loop as we write a program that prints even numbers…
Viewers learn about the scanner class in this video and are introduced to receiving user input for their programs. Additionally, objects, conditional statements, and loops are used to help reinforce the concepts. Introduce Scanner class: Importing…

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question