Oracle Java Interview Questions & Answers Set-14

«« Previous
Next »»

Hibernate Interview Questions

261) What is hibernate?
Ans: Hibernate is an open-source and lightweight ORM tool that is used to store, manipulate and retrieve data from the database.

262) What is ORM?
Ans: ORM is an acronym for Object/Relational mapping. It is a programming strategy to map object with the data stored in the database. It simplifies data creation, data manipulation and data access.

263) Explain hibernate architecture?
Ans: Hibernate architecture comprises of many interfaces such as Configuration, SessionFactory, Session, Transaction etc.

264) What are the core interfaces of Hibernate?
Ans: The core interfaces of Hibernate framework are:
  • Configuration
  • SessionFactory
  • Session
  • Query
  • Criteria
  • Transaction

265) What is SessionFactory?
Ans: SessionFactory provides the instance of Session. It is a factory of Session. It holds the data of second level cache that is not enabled by default.

266) Is SessionFactory a thread-safe object?
Ans: Yes, SessionFactory is a thread-safe object, many threads cannot access it simultaneously.

267) What is Session?
Ans: It maintains a connection between hibernate application and database.

It provides methods to store, update, delete or fetch data from the database such as persist(), update(), delete(), load(), get() etc.
It is a factory of Query, Criteria and Transaction i.e. it provides factory methods to return these instances.

268) Is Session a thread-safe object?
Ans: No, Session is not a thread-safe object, many threads can access it simultaneously. In other words, you can share it between threads.

269) What is the difference between and session.persist() method?

returns the identifier (Serializable) of the instance. return nothing because its return type is void.
Syn: public Serializable save(Object o) Syn: public void persist(Object o)

270) What is the difference between get and load method?

Ans: The differences between get() and load() methods are given below.

Returns null if object is not found.
Throws ObjectNotFoundException if object is not found.
get() method always hit the database.
load() method doesn't hit the database.
It returns real object not proxy.
It returns proxy object.
It should be used if you are not sure about the existence of instance.
It should be used if you are sure that instance exists.

271) What is the difference between update and merge method?

Ans: The differences between update() and merge() methods are given below.

update() method
merge() method
Update means to edit something.
Merge means to combine something.
update() should be used if session doesn't contain an already persistent state with same id. It means update should be used inside the session only. After closing the session it will throw error.
merge() should be used if you don't know the state of the session, means you want to make modification at any time.

Let's try to understand the difference by the example given below:

SessionFactory factory = cfg.buildSessionFactory();  
Session session1 = factory.openSession();  
Employee e1 = (Employee) session1.get(Employee.class, Integer.valueOf(101));//passing id of employee  
Session session2 = factory.openSession();  
Employee e2 = (Employee) session1.get(Employee.class, Integer.valueOf(101));//passing same id  
Transaction tx=session2.beginTransaction();  

After closing session1, e1 is in detached state. It will not be in session1 cache. So if you call update() method, it will throw an error.

Then, we opened another session and loaded the same Employee instance. If we call merge in session2, changes of e1 will be merged in e2.

672) What are the states of object in hibernate?
Ans: There are 3 states of object (instance) in hibernate.
  1. Transient: The object is in transient state if it is just created but has no primary key (identifier) and not associated with session.
  2. Persistent: The object is in persistent state if session is open, and you just saved the instance in the database or retrieved the instance from the database.
  3. Detached: The object is in detached state if session is closed. After detached state, object comes to persistent state if you call lock() or update() method.

673) What are the inheritance mapping strategies?
Ans: There are 3 ways of inheritance mapping in hibernate.
  1. Table per hierarchy
  2. Table per concrete class
  3. Table per subclass

674)  How to make a immutable class in hibernate?
Ans: If you mark a class as mutable="false", class will be treated as an immutable class. By default, it is mutable="true".

675) What is automatic dirty checking in hibernate?
Ans: The automatic dirty checking feature of hibernate, calls update statement automatically on the objects that are modified in a transaction.

Let's understand it by the example given below:

SessionFactory factory = cfg.buildSessionFactory();  
Session session1 = factory.openSession();  
Transaction tx=session2.beginTransaction();  
Employee e1 = (Employee) session1.get(Employee.class, Integer.valueOf(101));  

Here, after getting employee instance e1 and we are changing the state of e1.

After changing the state, we are committing the transaction. In such case, state will be updated automatically. This is known as dirty checking in hibernate.

676) How many types of association mapping are possible in hibernate?
Ans: There can be 4 types of association mapping in hibernate.
  1. One to One
  2. One to Many
  3. Many to One
  4. Many to Many

277) Is it possible to perform collection mapping with One-to-One and Many-to-One?
Ans: No, collection mapping can only be performed with One-to-Many and Many-to-Many

278) What is lazy loading in hibernate?
Ans: Lazy loading in hibernate improves the performance. It loads the child objects on demand.

Since Hibernate 3, lazy loading is enabled by default, you don't need to do lazy="true". It means not to load the child objects when parent is loaded.

279) What is HQL (Hibernate Query Language)?
Ans: Hibernate Query Language is known as an object oriented query language. It is like structured query language (SQL).

The main advantage of HQL over SQL is:
  1. You don't need to learn SQL
  2. Database independent
  3. Simple to write query

280) What is the difference between first level cache and second level cache?
First Level Cache
Second Level Cache
First Level Cache is associated with Session.Second Level Cache is associated with SessionFactory.
It is enabled by default.It is not enabled by default.

«« Previous
Next »»