àHibernate-Mappings:
àWhenever we want to save an
Entity obj we need it corresponding table in the DB. That means one class obj
will related to one table. But it is always possible bcz in real world business
applications every obj will not be in an isolated state and they will be
related with another obj’s for business requirements. So obj’s never be in an
isolated state.
àWe can relate one obj with
another obj in 2-ways
1.
Using Inheritance
a)
Generalization
b)
Realization
2.
Using Association
a)
Association
b)
Aggregation
c)
Composition
àAssociation means one
obj is linked to another obj but there will not be any owner of that
relationship that means the life time of the parent and child are independent
with each other. That means parent is deleted then child will not be removed
and there is no owner b/w them.
àAggregation means one
obj is linked to another obj and there will be an owner of that relationship.
But here also life time of the parent and child are independent with each
other. That means if owner is deleted then child will not be removed.
à Composition means one
obj is linked or contains inside another obj and there will be an owner of that
relationship. But here also life time of the parent and child are dependent
with each other. That means if owner is deleted then child also will be
removed.
àLet us take we have a class
Teacher, Principle then we wanted to store Teacher info and Principle info
where Principle is also a Teacher.
àIf at all we wanted to store a
Teacher class obj then we need to create a table for that class and relating
attributes to columns in DB. And if we want to store the Principle info then we
need to store Principle info which contains attributes of Teacher class also,
so in order to store Principle info we should re-declare the attributes of
Teacher class in Principle due to the duplication will happen hence we need to
extend form Teacher. But in order to store the Principle info we are using obj
relation as Inheritance but there is no Inheritance in the Relational DB s/m’s
to Inherit columns of Teacher into the Principle table hence we are unable to
store the data in the DB-table bcz all attributes of the class are not
physically available in the Principle class and there is no Inheritance concept
in the DB. So this is 1st problem when we are storing the relational
obj data into the corresponding table.
That means as we cannot
impose directly as obj relation to its table relation in DB i.e Inheritance is
there within the obj’s but Inheritance is not there with DB tables. That means
the way we relating the obj’s is different from the way we relating the data in
Relational model is different, the tables will expresses the data in an rows
and columns using PK and FK keys and the obj’s will express the relation in
terms of hierarchical manner using Inheritance or Association. So how we can be
persist the data in to the tables using obj’ relations. This is the problem we
are facing while working with ORM-Tech and this problem is called as "Impedance mismatch" problem.
Similarly there are
multiple problems while working with ORM-Tech and all these are called as "Impedance
mismatch" problems. There are 5-problems and they are
1.
Granularity
2.
Subtypes (Inheritance)
3.
Navigation
4.
Identity
5.
Association
àImpedance mismatch:
àImpedance mismatch means the way
we modelling the obj’s using object oriented prog language and the way we are
trying to store the data in an Relational Model will be not be in sink. That
means there is mis-match b/w the obj relation model to Relational DB model is
called as "Impedance mismatch".
àTo avoid the above Impedance
mismatch problems ORM-Tech given a solution called as Mappings-Concept.
1.
Granularity mismatch:
The
no.of obj’s that we have and the no.of underlying tables we have to persist is
always may not be same. So in such a way how can we persist and how can
retrieve the data this is the one problem.
Storing
more classes ob’sàin less tables.
2.
Subtypes:
How we
can we persist data if one class is inheriting from another class.
3.
Navigation:
Ex:
class Address {
private
String aadrLine1;
private
String aadrLine1;
private
String city;
private
String state;
}
class Person {
private
int personId;
private
String name;
}
àIf we store Person and
Address in 2-different tables then how can we get the Person and Address when
we are fetch the data in obj modelling bcz classes will not express the
relationships directly bcz one person will have many Addresses and many
Addresses belongs to one Person and many persons can have many Addresses that
means by looking at the classes we cannot easily determine the relationships as
one-one or one-many or many-many that means we navigate (trace) the obj
relation directly by looking at the classes to build the join conditions while
fetching the data.
àperson.address.city.equals(hyd);
This is
the obj model but how the join can created to get the data we cannot easily
determine using obj relation to the DB-model.
That
means navigation talks about Finding the relation is difficult while fetching
or retrieving the data.
4.
Identity:
àEvery java obj will
have 2-identities equals() and == to identify whether both obj’s are same or
not.
àSimilarly in
Relational DB we have PK to identify the row uniquely.
à
Person person1=new Person();
person1.setPersonId(1);
person1.setName("DB");
session.save(person1);
session.commit();
Person person2=new Person();
person2.setPersonId(1);
person2.setName("DB");
session.save(person2);
session.commit();
àIn java we can create
multiple obj’s but it should not permit to create multiple obj’s with the same
id to match the relational identity. But it is not so simple to maintain the
obj identity an relational identity to be same bcz java obj’s can create
multiple obj’s for a same class. That means there is problem how we can
restrict or ensure to create an obj per one row of a Relational model DB table
so that object identity and DB identity will be in sink or will be match.
àThat means we should
not allow to create multiple obj’s with same identity. That means this problem
is already solved by using the PK while working with the Cacheing. That means
cache will not allow to create multiple obj’s to create if the record is
already associated with the session.
5.
Association:
àHow does the data can
be persisted in the table if obj is even related to with Association that means
the obj which contains another obj has to be persisted in DB by translating
those obj as relational model. So we cannot identify the relation easily to persist
the data in to the Relational DB.
Ex:
class Person
{
private String personId;
private String name;
private Passenger passenger;
}
class
Passenger {
private String tktNo;
private String noOfTickets;
}
àHere one person can
have multiple tickets so we cannot tell by looking at the obj relation in which
way the data has been persisted in the DB.
àNote that Navigation
talks about identifying the relationships while retrieving the data and
Association impedance mismatch will talks about identifying the relation while
persisting the data.
Hence to avoid the
above Impedance mismatch problems ORM-Tech given a solution called as
Mappings-Concept, and by using this Mapping Concept we will try to resolve all
the problems one by one.
Comments
Post a Comment