KEMBAR78
Hibernate Interview Questions (2023) - InterviewBit | PDF | Method (Computer Programming) | Databases
0% found this document useful (0 votes)
595 views65 pages

Hibernate Interview Questions (2023) - InterviewBit

The document provides an overview of Hibernate interview questions and answers. It discusses key concepts in Hibernate like ORM, session and session factory, lazy loading, caching, inheritance mapping and more. The questions range from basic to more advanced topics to help prepare for Hibernate interviews.

Uploaded by

Ikramul Haque
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
595 views65 pages

Hibernate Interview Questions (2023) - InterviewBit

The document provides an overview of Hibernate interview questions and answers. It discusses key concepts in Hibernate like ORM, session and session factory, lazy loading, caching, inheritance mapping and more. The questions range from basic to more advanced topics to help prepare for Hibernate interviews.

Uploaded by

Ikramul Haque
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 65

Hibernate Interview Questions For Freshers

3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

1. What is ORM in Hibernate?


Hibernate ORMstands forObject Relational Mapping. This is a mapping tool pattern
mainly used for converting data stored in a relational database to an object used in object-
oriented programming constructs. This tool also helps greatly in simplifying data retrieval,
creation, and manipulation.

https://www.interviewbit.com/hibernate-interview-questions/ 1/65
Object Relational Mapping
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

2. What are the advantages of Hibernate over JDBC?


- The advantages of Hibernate over JDBC are listed below:
Clean Readable Code:Using hibernate, helps in eliminating a lot of JDBC API-based
boiler-plate codes, thereby making the code look cleaner and readable.
HQL (Hibernate Query Language):Hibernate provides HQL which is closer to Java
and is object-oriented in nature. This helps in reducing the burden on developers for
writing database independent queries. In JDBC, this is not the case. A developer has to
know the database-specific codes.
Transaction Management:JDBC doesn't support implicit transaction management. It is
upon the developer to write transaction management code using commit and rollback
methods. Whereas, Hibernate implicity provides this feature.
Exception Handling:Hibernate wraps the JDBC exceptions and throws unchecked
exceptions like JDBCException or HibernateException. This along with the built-in
transaction management system helps developers to avoid writing multiple try-catch
blocks to handle exceptions. In the case of JDBC, it throws a checked exception called
https://www.interviewbit.com/hibernate-interview-questions/ 2/65
SQLException thereby mandating the developer to write try-catch blocks to handle this
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

exception at compile time.


Special Features:Hibernate supports OOPs features like inheritance, associations and
also supports collections. These are not available in JDBC.
3. What are some of the important interfaces of Hibernate framework?
Hibernate core interfaces are:
Configuration
SessionFactory
Session
Criteria
Query
Transaction

https://www.interviewbit.com/hibernate-interview-questions/ 3/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

You can download a PDF version of Hibernate Download


Interview Questions. PDF

4. What is a Session in Hibernate?


A session is an object that maintains the connection between Java object application and
database. Session also has methods for storing, retrieving, modifying or deleting data from
database using methods like persist(), load(), get(), update(), delete(), etc. Additionally, It has
factory methods to return Query, Criteria, and Transaction objects.
5. What is a SessionFactory?
SessionFactory provides an instance ofSession. It is a factory class that gives the
Sessionobjectsbased on the configuration parameters in order to establish the connection
to the database.
As a good practice, the application generally has a single instance of SessionFactory. The
https://www.interviewbit.com/hibernate-interview-questions/ 4/65
internal state of a SessionFactory which includes metadata about ORM is immutable, i.e once
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

the instance is created, it cannot be changed.


This also provides the facility to get information like statistics and metadata related to a class,
query executions, etc. It also holds second-level cache data if enabled.
6. What do you think about the statement - “session being a thread-
safe object”?
No, Session is not a thread-safe object which means that any number of threads can access
data from it simultaneously.
7. Can you explain what is lazy loading in hibernate?
Lazy loading is mainly used for improving the application performance by helping to load the
child objects on demand.
It is to be noted that, since Hibernate 3 version, this feature has been enabled by default. This
signifies that child objects are not loaded until the parent gets loaded.
https://www.interviewbit.com/hibernate-interview-questions/ 5/65
8. What is the difference between first level cache and second level
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

cache?
Hibernate has 2 cache types. First level and second level cache for which the difference is
given below:
First Level Cache Second Level Cache
This is local to the Session object and This cache is maintained at the SessionFactory
cannot be shared between multiple level and shared among all sessions in Hibernate.
sessions.
This cache is enabled by default and there This is disabled by default, but we can enable it
is no way to disable it. through configuration.
The first level cache is available only until The second-level cache is available through the
the session is open, once the session is application’s life cycle, it is only destroyed and
closed, the first level cache is destroyed. recreated when an application is restarted.

https://www.interviewbit.com/hibernate-interview-questions/ 6/65
If an entity or object is loaded by calling the get() method then Hibernate first checked the
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

first level cache, if it doesn’t find the object then it goes to the second level cache if
configured. If the object is not found then it finally goes to the database and returns the
object, if there is no corresponding row in the table then it returns null.
9. What can you tell about Hibernate Configuration File?
Hibernate Configuration Fileorhibernate.cfg.xmlis one of the most required
configuration files in Hibernate. By default, this file is placed under the src/main/resource
folder.
The file contains database related configurations and session-related configurations.
Hibernate facilitates providing the configuration either in an XML file (like hibernate.cfg.xml)
or a properties file (like hibernate.properties).
This file is used to define the below information:
Database connection details: Driver class, URL, username, and password.
There must be one configuration file for each database used in the application, suppose
if we want to connect with 2 databases, then we must create 2 configuration files with
different names.
https://www.interviewbit.com/hibernate-interview-questions/ 7/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Hibernate properties: Dialect, show_sql, second_level_cache, and mapping file names.


10. How do you create an immutable class in hibernate?
Immutable class in hibernate creation could be in the following way. If we are using the XML
form of configuration, then a class can be made immutable by markingmutable=false. The
default value is true there which indicating that the class was not created by default.
In the case of using annotations, immutable classes in hibernate can also be created by using
@Immutable annotation.
11. Can you explain the concept behind Hibernate Inheritance
Mapping?
Java is an Object-Oriented Programming Language and Inheritance is one of the most
important pillars of object-oriented principles. To represent any models in Java, inheritance is
most commonly used to simplify and simplify the relationship. But, there is a catch. Relational
databases do not support inheritance. They have a flat structure.

https://www.interviewbit.com/hibernate-interview-questions/ 8/65
Hibernate’s Inheritance Mapping strategies deal with solving how to hibernate being an ORM
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

tries to map this problem between the inheritance of Java and flat structure of Databases.
Consider the example where we have to divide InterviewBitEmployee into Contract and
Permanent Employees represented by IBContractEmployee and IBPermanentEmployee
classes respectively. Now the task of hibernate is to represent these 2 employee types by
considering the below restrictions:
The general employee details are defined in the parent InterviewBitEmployee class. 
Contract and Permanent employee-specific details are stored in IBContractEmployee and
IBPermanentEmployee classes respectively
The class diagram of this system is as shown below:

https://www.interviewbit.com/hibernate-interview-questions/ 9/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Hibernate’s Inheritance Mapping


https://www.interviewbit.com/hibernate-interview-questions/ 10/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

There are different inheritance mapping strategies available:


Single Table Strategy
Table Per Class Strategy
Mapped Super Class Strategy
Joined Table Strategy
12. Is hibernate prone to SQL injection attack?
SQL injectionattackis a serious vulnerability in terms of web security wherein an attacker
can interfere with the queries made by an application/website to its database thereby
allowing the attacker to view sensitive data which are generally irretrievable. It can also give
the attacker to modify/ remove the data resulting in damages to the application behavior.
Hibernate does not provide immunity to SQL Injection. However, following good practices
avoids SQL injection attacks. It is always advisable to follow any of the below options:
Incorporate Prepared Statements that use Parameterized Queries.
https://www.interviewbit.com/hibernate-interview-questions/ 11/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Use Stored Procedures.


Ensure data sanity by doing input validation.
Intermediate Interview Questions
13. Explain hibernate mapping file
Hibernate mapping file is an XML file that is used for defining the entity bean fields and
corresponding database column mappings.
These files are useful when the project uses third-party classes where JPA annotations
provided by hibernating cannot be used.
In the previous example, we have defined the mapping resource as
“InterviewBitEmployee.hbm.xml” in the config file. Let us see what that sample hbm.xml file
looks like:
<?xml version = "1.0" encoding = "utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

https://www.interviewbit.com/hibernate-interview-questions/ 12/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

<hibernate-mapping>
<!-- What class is mapped to what database table-->
<class name = "InterviewBitEmployee" table = "InterviewBitEmployee">

<meta attribute = "class-description">


This class contains the details of employees of InterviewBit.
</meta>

<id name = "id" type = "int" column = "employee_id">


<generator class="native"/>
</id>

<property name = "fullName" column = "full_name" type = "string"/>


<property name = "email" column = "email" type = "string"/>

</class>
</hibernate-mapping>

14. What are the most commonly used annotations available to support
hibernate mapping?
https://www.interviewbit.com/hibernate-interview-questions/ 13/65
Hibernate framework provides support to JPA annotations and other useful annotations in the
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

org.hibernate.annotations package. Some of them are as follows:


javax.persistence.Entity: This annotation is used on the model classes by using
“@Entity” and tells that the classes are entity beans.
javax.persistence.Table: This annotation is used on the model classes by using “@Table”
and tells that the class maps to the table name in the database.
javax.persistence.Access: This is used as “@Access” and is used for defining the access
type of either field or property. When nothing is specified, the default value taken is
“field”.
javax.persistence.Id: This is used as “@Id” and is used on the attribute in a class to
indicate that attribute is the primary key in the bean entity.
javax.persistence.EmbeddedId: Used as “@EmbeddedId” upon the attribute and
indicates it is a composite primary key of the bean entity.
javax.persistence.Column: “@Column” is used for defining the column name in the
database table.
https://www.interviewbit.com/hibernate-interview-questions/ 14/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

javax.persistence.GeneratedValue: “@GeneratedValue” is used for defining the strategy


used for primary key generation. This annotation is used along with
javax.persistence.GenerationType enum.
javax.persistence.OneToOne: “@OneToOne” is used for defining the one-to-one
mapping between two bean entities. Similarly, hibernate provides OneToMany,
ManyToOne and ManyToMany annotations for defining different mapping types.
org.hibernate.annotations.Cascade: “@Cascade” annotation is used for defining the
cascading action between two bean entities. It is used with
org.hibernate.annotations.CascadeType enum to define the type of cascading.
Following is a sample class where we have used the above listed annotations:
package com.dev.interviewbit.model;
import javax.persistence.Access;
import javax.persistence.AccessType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

https://www.interviewbit.com/hibernate-interview-questions/ 15/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

import javax.persistence.OneToOne;
import javax.persistence.Table;

import org.hibernate.annotations.Cascade;

@Entity
@Table(name = "InterviewBitEmployee")
@Access(value=AccessType.FIELD)
public class InterviewBitEmployee {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "employee_id")
private long id;

@Column(name = "full_name")
private String fullName;

@Column(name = "email")
private String email;

https://www.interviewbit.com/hibernate-interview-questions/ 16/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

@OneToOne(mappedBy = "employee")
@Cascade(value = org.hibernate.annotations.CascadeType.ALL)
private Address address;

//getters and setters methods


}

15. Explain Hibernate architecture


The Hibernate architecture consists of many objects such as a persistent object, session
factory, session, query, transaction, etc. Applications developed using Hibernate is mainly
categorized into 4 parts:
Java Application
Hibernate framework - Configuration and Mapping Files
Internal API -
JDBC (Java Database Connectivity)
JTA (Java Transaction API)
JNDI (Java Naming Directory Interface).
https://www.interviewbit.com/hibernate-interview-questions/ 17/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Database - MySQL, PostGreSQL, Oracle, etc

https://www.interviewbit.com/hibernate-interview-questions/ 18/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

https://www.interviewbit.com/hibernate-interview-questions/ 19/65
Hibernate Architecture
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

The main elements of Hibernate framework are:


SessionFactory: This provides a factory method to get session objects and clients of
ConnectionProvider. It holds a second-level cache (optional) of data.
Session: This is a short-lived object that acts as an interface between the java
application objects and database data.
The session can be used to generate transaction, query, and criteria objects.
It also has a mandatory first-level cache of data.
Transaction: This object specifies the atomic unit of work and has methods useful for
transaction management. This is optional.
ConnectionProvider: This is a factory of JDBC connection objects and it provides an
abstraction to the application from the DriverManager. This is optional.
TransactionFactory: This is a factory of Transaction objects. It is optional.
https://www.interviewbit.com/hibernate-interview-questions/ 20/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Hibernate Objects
16. Can you tell the difference between getCurrentSession and
openSession methods?
https://www.interviewbit.com/hibernate-interview-questions/ 21/65
Both the methods are provided by the Session Factory. The main differences are given below:
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

getCurrentSession() openSession()
This method returns the session bound to the context. This method always opens a
new session.
This session object scope belongs to the hibernate context A new session object has to
and to make this work hibernate configuration file has to be be created for each request in
modified by adding <property name = a multi-threaded environment.
"hibernate.current_session_context_class"> Hence, you need not configure
thread </property>. If not added, then using the method any property to call this
would throw an HibernateException. method.
It's the developer’s
This session object gets closed once the session factory is responsibility to close this
closed. object once all the database
operations are done.
In single threaded
I i l th d d i t thi th di f t th i t iti l th
https://www.interviewbit.com/hibernate-interview-questions/ 22/65
Apart from these two methods, there is another method openStatelessSession() and this
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

method returns a stateless session object.


17. Differentiate between save() and saveOrUpdate() methods in
hibernate session.
Both the methods save records to the table in the database in case there are no records with
the primary key in the table. However, the main differences between these two are listed
below:
save() saveOrUpdate()
save() generates a new identifier Session.saveOrUpdate() can either INSERT or UPDATE
and INSERT record into a based upon existence of a record.
database
The insertion fails if the primary In case the primary key already exists, then the record is
key already exists in the table. updated.
The return type is Serializable The return type of the saveOrUpdate() method is void.
which is the newly generated
https://www.interviewbit.com/hibernate-interview-questions/ 23/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

save() saveOrUpdate()
identifier id value as a Serializable
object.
This method is used to bring only This method can bring both transient (new) and detached
a transient object to a persistent (existing) objects into a persistent state. It is often used to
h d h d bj i S i
Clearly, saveOrUpdate() is more flexible in terms of use but it involves extra processing to find
out whether a record already exists in the table or not.
18. Differentiate between get() and load() in Hibernate session
These are the methods to get data from the database. The primary differences between get
and load in Hibernate are given below:
get() load()
This method gets the data from the This method returns a proxy object and loads the data
database as soon as it is called. only when it is required.

https://www.interviewbit.com/hibernate-interview-questions/ 24/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

get() load()
The database is hit every time the The database is hit only when it is really needed and
this is called Lazy Loading which makes the method
method is called. better.
The method returns null if the object The method throws ObjectNotFoundException if the
is not found. object is not found.
This method should be used if we This method is to be used when we know for sure that
are unsure about the existence of the data is present in the database.
data in the database.
19. What is criteria API in hibernate?
Criteria API in Hibernate helps developers to builddynamic criteria querieson the
persistence database. Criteria API is a more powerful and flexible alternative to HQL
(Hibernate Query Language) queries for creating dynamic queries.
This API allows to programmatically development criteria query objects. The
org.hibernate.Criteria interface is used for these purposes. The Session interface of hibernate
https://www.interviewbit.com/hibernate-interview-questions/ 25/65
framework has createCriteria() method that takes the persistent object’s class or its entity
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

name as the parameters and returns persistence object instance the criteria query is
executed.
It also makes it very easy to incorporate restrictions to selectively retrieve data from the
database. It can be achieved by using the add() method which accepts the
org.hibernate.criterion.Criterion object representing individual restriction.
Usage examples:
To return all the data of InterviewBitEmployee entity class.
Criteria criteria = session.createCriteria(InterviewBitEmployee.class);
List<InterviewBitEmployee> results = criteria.list();

To retrive objects whose property has value equal to the restriction, we use
Restrictions.eq() method. For example, to fetch all records with name ‘Hibernate’:

https://www.interviewbit.com/hibernate-interview-questions/ 26/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Criteria criteria= session.createCriteria(InterviewBitEmployee.class);


criteria.add(Restrictions.eq("fullName","Hibernate"));
List<InterviewBitEmployee> results = criteria.list();

To get objects whose property has the value “not equal to” the restriction, we use
Restrictions.ne() method. For example, to fetch all the records whose employee’s
name is not Hibernate:
Criteria criteria= session.createCriteria(InterviewBitEmployee.class);
criteria.add(Restrictions.ne("fullName","Hibernate"));
List<Employee> results = criteria.list()

To retrieve all objects whose property matches a given pattern, we use


Restrictions.like() (for case sensitivenes) and Restrictions.ilike()(for case
insensitiveness)
Criteria criteria= session.createCriteria(InterviewBitEmployee.class);
criteria.add(Restrictions.like("fullName","Hib%",MatchMode.ANYWHERE));
List<InterviewBitEmployee> results = criteria.list();

https://www.interviewbit.com/hibernate-interview-questions/ 27/65
Similarly, it also has other methods like isNull(), isNotNull(), gt(), ge(), lt(), le() etc for adding
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

more varieties of restrictions. It has to be noted that for Hibernate 5 onwards, the functions
returning an object of typeCriteria are deprecated. Hibernate 5 version has provided
interfaces like CriteriaBuilder and CriteriaQuery to serve the purpose:
javax.persistence.criteria.CriteriaBuilder
javax.persistence.criteria.CriteriaQuery

// Create CriteriaBuilder
CriteriaBuilder builder = session.getCriteriaBuilder();

// Create CriteriaQuery
CriteriaQuery<YourClass> criteria = builder.createQuery(YourClass.class);

For introducing restrictions in CriteriaQuery, we can use the CriteriaQuery.where method


which is analogous to using the WHERE clause in a JPQL query.
20. What is HQL?
Hibernate Query Language (HQL)is used as an extension ofSQL. It is very simple,
efficient, and very flexible for performing complex operations on relational databases without
https://www.interviewbit.com/hibernate-interview-questions/ 28/65
writing complicated queries. HQL is the object-oriented representation of query language, i.e
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

instead of using table name, we make use of the class name which makes this language
independent of any database.
This makes use of the Query interface provided by Hibernate. The Query object is obtained by
calling the createQuery() method of the hibernate Session interface.
Following are the most commonly used methods of query interface:
public int executeUpdate() : This method is used to run the update/delete query.
public List list(): This method returns the result as a list.
public Query setFirstResult(int rowNumber): This method accepts the row number as the
parameter using which the record of that row number would be retrieved.
public Query setMaxResult(int rowsCount): This method returns a maximum up to the
specified rowCount while retrieving from the database.
public Query setParameter(int position, Object value): This method sets the value to the
attribute/column at a particular position. This method follows the JDBC style of the query
parameter.
https://www.interviewbit.com/hibernate-interview-questions/ 29/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

public Query setParameter(String name, Object value): This method sets the value to a
named query parameter.
Example: To get a list of all records from InterviewBitEmployee Table:
Query query=session.createQuery("from InterviewBitEmployee");
List<InterviewBitEmployee> list=query.list();
System.out.println(list.get(0));

21. Can you tell something about one to many associations and how
can we use them in Hibernate?
Theone-to-many associationis the most commonly used which indicates that one object
is linked/associated with multiple objects.
For example, one person can own multiple cars.

https://www.interviewbit.com/hibernate-interview-questions/ 30/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

https://www.interviewbit.com/hibernate-interview-questions/ 31/65
Hibernate One To Many Mapping
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

In Hibernate, we can achieve this by using @OnetoMany of JPA annotations in the model
classes. Consider the above example of a person having multiple cars as shown below:
@Entity
@Table(name="Person")
public class Person {

//...

@OneToMany(mappedBy="owner")
private Set<Car> cars;

// getters and setters


}

In the Person class, we have defined the car's property to have @OneToMany association.
The Car class would have owned property that is used by the mappedBy variable in the
Person class. The Car class is as shown below:
https://www.interviewbit.com/hibernate-interview-questions/ 32/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

@Entity
@Table(name="Car")
public class Car {

// Other Properties

@ManyToOne
@JoinColumn(name="person_id", nullable=false)
private Person owner;

public Car() {}

// getters and setters


}

@ManyToOne annotation indicates that many instances of an entity are mapped to one
instance of another entity – many cars of one person.
22. What are Many to Many associations?
https://www.interviewbit.com/hibernate-interview-questions/ 33/65
Many-to-many associationindicates that there are multiple relations between the
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

instances of two entities. We could take the example of multiple students taking part in
multiple courses and vice versa.
Since both the student and course entities refer to each other by means of foreign keys, we
represent this relationship technically by creating a separate table to hold these foreign keys.

https://www.interviewbit.com/hibernate-interview-questions/ 34/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

https://www.interviewbit.com/hibernate-interview-questions/ 35/65
Many To Many Associations
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Here, Student-Course Table is called the Join Table where the student_id and course_id
would form the composite primary key.
23. What does session.lock() method in hibernate do?
session.lock()method is used to reattach a detached object to the
session.session.lock()method does not check for any data synchronization between the
database and the object in the persistence context and hence this reattachment might lead to
loss of data synchronization.
24. What is hibernate caching?
Hibernate cachingis the strategy for improving the application performance by pooling
objects in the cache so that the queries are executed faster. Hibernate caching is particularly
useful when fetching the same data that is executed multiple times. Rather than hitting the
database, we can just access the data from the cache. This results in reduced throughput
time of the application.
Types of Hibernate Caching
https://www.interviewbit.com/hibernate-interview-questions/ 36/65
First Level Cache:
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

This level is enabled by default.


The first level cache resides in the hibernate session object.
Since it belongs to the session object, the scope of the data stored here will not be
available to the entire application as an application can make use of multiple session
objects.

https://www.interviewbit.com/hibernate-interview-questions/ 37/65
First Level Caching
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Second Level Cache:


Second level cache resides in the SessionFactory object and due to this, the data is
accessible by the entire application.
This is not available by default. It has to be enabled explicitly.
EH (Easy Hibernate) Cache, Swarm Cache, OS Cache, JBoss Cache are some example
cache providers.

https://www.interviewbit.com/hibernate-interview-questions/ 38/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Second Level Caching


25. When is merge() method of the hibernate session useful?
https://www.interviewbit.com/hibernate-interview-questions/ 39/65
Merge() method can be used for updating existing values. The specialty of this method is,
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

once the existing values are updated, the method creates a copy from the entity object and
returns it. This result object goes into the persistent context and is then tracked for any
changes. The object that was initially used is not tracked.
26. Collection mapping can be done using One-to-One and Many-to-
One Associations. What do you think?
False, collection mapping is possible only withOne-to-ManyandMany-to-Many
associations.
27. Can you tell the difference between setMaxResults() and
setFetchSize() of Query?
setMaxResults() the function works similar to LIMIT in SQL. Here, we set the maximum
number of rows that we want to be returned. This method is implemented by all database
drivers.
setFetchSize() works for optimizing how Hibernate sends the result to the caller for example:
are the results buffered, are they sent in different size chunks, etc. This method is not
https://www.interviewbit.com/hibernate-interview-questions/ 40/65
implemented by all the database drivers.
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

28. Does Hibernate support Native SQL Queries?


Yes, it does. Hibernate provides the createSQLQuery() method to let a developer call the
native SQL statement directly and returns a Query object.
Consider the example where you want to get employee data with the full name “Hibernate”.
We don’t want to use HQL-based features, instead, we want to write our own SQL queries. In
this case, the code would be:
Query query = session.createSQLQuery( "select * from interviewbit_employee
.addEntity(InterviewBitEmployee.class)
.setParameter("fullName", "Hibernate"); //named paramete
List result = query.list();

Alternatively, native queries can also be supported when using NamedQueries.


Hibernate Interview Questions For Experienced
https://www.interviewbit.com/hibernate-interview-questions/ 41/65
29. What happens when the no-args constructor is absent in the Entity
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

bean?
Hibernate framework internally uses Reflection API for creating entity bean instances when
get() or load() methods are called. The method Class.newInstance() is used which requires a
no-args constructor to be present. When we don't have this constructor in the entity beans,
then hibernate fails to instantiate the bean and hence it throws HibernateException.
30. Can we declare the Entity class final?
No, we should not define the entity class final because hibernate uses proxy classes and
objects for lazy loading of data and hits the database only when it is absolutely needed. This
is achieved by extending the entity bean. If the entity class (or bean) is made final, then it cant
be extended and hence lazy loading can not be supported.
31. What are the states of a persistent entity?
A persistent entity can exist in any of the following states:
Transient:
https://www.interviewbit.com/hibernate-interview-questions/ 42/65
This state is the initial state of any entity object.
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Once the instance of the entity class is created, then the object is said to have entered a
transient state. These objects exist in heap memory.
In this state, the object is not linked to any session. Hence, it is not related to any
database due to which any changes in the data object don't affect the data in the
database.
InterviewBitEmployee employee=new InterviewBitEmployee(); //The object is i
employee.setId(101);
employee.setFullName("Hibernate"); 
employee.setEmail("hibernate@interviewbit.com");

Persistent:
This state is entered whenever the object is linked or associated with the session.
An object is said to be in a persistence state whenever we save or persist an object in the
database. Each object corresponds to the row in the database table. Any modifications to
the data in this state cause changes in the record in the database.
Following methods can be used upon the persistence object:
https://www.interviewbit.com/hibernate-interview-questions/ 43/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

session.save(record);
session.persist(record);
session.update(record);
session.saveOrUpdate(record);
session.lock(record);
session.merge(record);

Detached:
The object enters this state whenever the session is closed or the cache is cleared.
Due to the object being no longer part of the session, any changes in the object will not
reflect in the corresponding row of the database. However, it would still have its
representation in the database.
In case the developer wants to persist changes of this object, it has to be reattached to
the hibernate session.
In order to achieve the reattachment, we can use the methods load(), merge(), refresh(),
update(), or save() methods on a new session by using the reference of the detached
object.
The object enters this state whenever any of the following methods are called:
https://www.interviewbit.com/hibernate-interview-questions/ 44/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

session.close();
session.clear();
session.detach(record);
session.evict(record);

https://www.interviewbit.com/hibernate-interview-questions/ 45/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

https://www.interviewbit.com/hibernate-interview-questions/ 46/65
Persistent Entity
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

32. Explain Query Cache


Hibernate framework provides an optional feature called cache region for the queries’
resultset. Additional configurations have to be done in code in order to enable this. The query
cache is useful for those queries which are most frequently called with the same parameters.
This increases the speed of the data retrieval and greatly improves performance for
commonly repetitive queries.
This does not cache the state of actual entities in the result set but it only stores the identifier
values and results of the value type. Hence, query cache should be always used in
association with second-level cache.
Configuration:
In the hibernate configuration XML file, set the use_query_cache property to true as shown
below:

https://www.interviewbit.com/hibernate-interview-questions/ 47/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

<property name="hibernate.cache.use_query_cache">true</property>

In the code, we need to do the below changes for the query object:
Query query = session.createQuery("from InterviewBitEmployee");
query.setCacheable(true);
query.setCacheRegion("IB_EMP");

33. Can you tell something about the N+1 SELECT problem in
Hibernate?
N+1 SELECT problem is due to the result of using lazy loading and on-demand fetching
strategy. Let's take an example. If you have an N items list and each item from the list has a
dependency on a collection of another object, say bid. In order to find the highest bid for each
item while using the lazy loading strategy, hibernate has to first fire 1 query to load all items
and then subsequently fire N queries to load big of each item. Hence, hibernate actually ends
up executing N+1 queries.
34. How to solve N+1 SELECT problem in Hibernate?
Some of the strategies followed for solving the N+1 SELECT problem are:
https://www.interviewbit.com/hibernate-interview-questions/ 48/65
Pre-fetch the records in batches which helps us to reduce the problem of N+1 to (N/K) +
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

1 where K refers to the size of the batch.


Subselect the fetching strategy
As last resort, try to avoid or disable lazy loading altogether.
35. What are the concurrency strategies available in hibernate?
Concurrency strategies are the mediators responsible for storing and retrieving items from the
cache. While enabling second-level cache, it is the responsibility of the developer to provide
what strategy is to be implemented to decide for each persistent class and collection.
Following are the concurrency strategies that are used:
Transactional:This is used in cases of updating data that most likely causes stale data
and this prevention is most critical to the application.
Read-Only:This is used when we don't want the data to be modified and can be used
for reference data only.
Read-Write:Here, data is mostly read and is used when the prevention of stale data is of
critical importance.
https://www.interviewbit.com/hibernate-interview-questions/ 49/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Non-strict-Read-Write:Using this strategy will ensure that there wouldn't be any


consistency between the database and cache. This strategy can be used when the data
can be modified and stale data is not of critical concern.
36. What is Single Table Strategy?
Single Table Strategy is a hibernate’s strategy for performing inheritance mapping. This
strategy is considered to be the best among all the other existing ones. Here, the inheritance
data hierarchy is stored in the single table by making use of a discriminator column which
determines to what class the record belongs.
For the example defined in the Hibernate Inheritance Mapping question above, if we follow
this single table strategy, then all the permanent and contract employees’ details are stored in
only one table called InterviewBitEmployee in the database and the employees would be
differentiated by making use of discriminator column named employee_type.
Hibernate provides @Inheritance annotation which takes strategy as the parameter. This is
used for defining what strategy we would be using. By giving them value,
InheritanceType.SINGLE_TABLE signifies that we are using a single table strategy for
mapping.
https://www.interviewbit.com/hibernate-interview-questions/ 50/65
@DiscriminatorColumn is used for specifying what is the discriminator column of the
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

table in the database corresponding to the entity.


@DiscriminatorValue is used for specifying what value differentiates the records of two
types.
The code snippet would be like this:
InterviewBitEmployee class:
@Entity
@Table(name = "InterviewBitEmployee")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "employee_type")
@NoArgsConstructor
@AllArgsConstructor
public class InterviewBitEmployee {
@Id
@Column(name = "employee_id")
private String employeeId;
private String fullName;

https://www.interviewbit.com/hibernate-interview-questions/ 51/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

private String email;


}

InterviewBitContractEmployee class:
@Entity
@DiscriminatorValue("contract")
@NoArgsConstructor
@AllArgsConstructor
public class InterviewBitContractEmployee extends InterviewBitEmployee {
private LocalDate contractStartDate;
private LocalDate contractEndDate;
private String agencyName;
}

InterviewBitPermanentEmployee class:
@Entity
@DiscriminatorValue("permanent")
@NoArgsConstructor

https://www.interviewbit.com/hibernate-interview-questions/ 52/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

@AllArgsConstructor
public class InterviewBitPermanentEmployee extends InterviewBitEmployee {
private LocalDate workStartDate;
private int numberOfLeaves;
}

37. Can you tell something about Table Per Class Strategy.
Table Per Class Strategy is another type of inheritance mapping strategy where each class in
the hierarchy has a corresponding mapping database table. For example, the
InterviewBitContractEmployee class details are stored in the interviewbit_contract_employee
table and InterviewBitPermanentEmployee class details are stored in
interviewbit_permanent_employee tables respectively. As the data is stored in different tables,
there will be no need for a discriminator column as done in a single table strategy.
Hibernate provides @Inheritance annotation which takes strategy as the parameter. This is
used for defining what strategy we would be using. By giving them value,
InheritanceType.TABLE_PER_CLASS, it signifies that we are using a table per class strategy
for mapping.
https://www.interviewbit.com/hibernate-interview-questions/ 53/65
The code snippet will be as shown below:
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

InterviewBitEmployee class:
@Entity(name = "interviewbit_employee")
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
@NoArgsConstructor
@AllArgsConstructor
public class InterviewBitEmployee {
@Id
@Column(name = "employee_id")
private String employeeId;
private String fullName;
private String email;
}

InterviewBitContractEmployee class:
@Entity(name = "interviewbit_contract_employee")
@Table(name = "interviewbit_contract_employee")

https://www.interviewbit.com/hibernate-interview-questions/ 54/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

@NoArgsConstructor
@AllArgsConstructor
public class InterviewBitContractEmployee extends InterviewBitEmployee {
private LocalDate contractStartDate;
private LocalDate contractEndDate;
private String agencyName;
}

InterviewBitPermanentEmployee class:
@Entity(name = "interviewbit_permanent_employee")
@Table(name = "interviewbit_permanent_employee")
@NoArgsConstructor
@AllArgsConstructor
public class InterviewBitPermanentEmployee extends InterviewBitEmployee {
private LocalDate workStartDate;
private int numberOfLeaves;
}

Disadvantages:
https://www.interviewbit.com/hibernate-interview-questions/ 55/65
This type of strategy offers less performance due to the need for additional joins to get
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

the data.
This strategy is not supported by all JPA providers.
Ordering is tricky in some cases since it is done based on a class and later by the
ordering criteria.
38. Can you tell something about Named SQL Query
A named SQL query is an expression represented in the form of a table. Here, SQL
expressions to select/retrieve rows and columns from one or more tables in one or more
databases can be specified. This is like using aliases to the queries.
In hibernate, we can make use of @NameQueries and @NameQuery annotations.
@NameQueries annotation is used for defining multiple named queries.
@NameQuery annotation is used for defining a single named query.
Code Snippet: We can define Named Query as shown below
@NamedQueries(
{
https://www.interviewbit.com/hibernate-interview-questions/ 56/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

@NamedQuery(
name = "findIBEmployeeByFullName",
query = "from InterviewBitEmployee e where e.fullName = :fullName"
)
}
)

:fullName refers to the parameter that is programmer defined and can be set using the
query.setParameter method while using the named query.
Usage:
TypedQuery query = session.getNamedQuery("findIBEmployeeByFullName");
query.setParameter("fullName","Hibernate");
List<InterviewBitEmployee> ibEmployees = query.getResultList();

The getNamedQuery method takes the name of the named query and returns the query
instance.
39. What are the benefits of NamedQuery?
https://www.interviewbit.com/hibernate-interview-questions/ 57/65
In order to understand the benefits of NamedQuery, let's first understand the disadvantage of
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

HQL and SQL. The main disadvantage of having HQL and SQL scattered across data access
objects is that it makes the code unreadable. Hence, as good practice, it is recommended to
group all HQL and SQL codes in one place and use only their reference in the actual data
access code. In order to achieve this, Hibernate gives us named queries.
A named query is a statically defined query with a predefined unchangeable query string.
They are validated when the session factory is created, thus making the application fail fast in
case of an error.
Conclusion
Hibernate is the most powerful open source ORM tool that is used for mapping java objects
with the database structures at run time. It has become more popular amongsoftware
developersdue to its nature of abstraction allowing developers to continue application
development by being database independent and focus just on the application business
logic.
Additional Resources
https://www.interviewbit.com/hibernate-interview-questions/ 58/65
Practice Coding
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Java Tutorials
Java Interview Questions
Hibernate Vs JPA
Hibernate MCQs
1. Which among the below do not belong to the core interface of Hibernate?
SessionManagement
Configuration
Session
Criteria
https://www.interviewbit.com/hibernate-interview-questions/ 59/65
2. Which method returns the proxy object?
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

getDatabase()
get()
loadDatabase()
load()
3. Which of the following method is used inside sessions only?
end()
merge()
update()
https://www.interviewbit.com/hibernate-interview-questions/ 60/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

kill()
4. Hibernate uses PersisterClassProvider by default.
True
False
There is no such class named PersisterClassProvider
Nothing is set by default
5. Which among the below is held by the Session object?
First Level Cache
Second Level Cache
https://www.interviewbit.com/hibernate-interview-questions/ 61/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Both First and Second Level Cache


None of the above
6. What are the ways to map tables in the case of Table per Concrete class where there
would be three tables in the database that have no relation to each other?
By self-creating the table for each class
By union-subclass element
Both a & b
None of the above
7. What holds the second level cache as per the Hibernate architecture?
https://www.interviewbit.com/hibernate-interview-questions/ 62/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

Session
SessionFactory
Connection
Transaction
8. Which of the following is true in the case of Hibernate annotations?
By using annotations, we ensure that all metadata is clubbed into java file thereby helping user to
understand the table and POJO structure simultaneously
They are the powerful means to provide the metadata of the Object and Relational Table
mapping.
Both of the above
https://www.interviewbit.com/hibernate-interview-questions/ 63/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

None of the above


9. Which method among the following options hits the database always?
getDatabase()
load()
get()
loadDatabase()
10. Which of the following statements is FALSE about Session?
Sessions can be shared between threads
It is lightweight and a non-threadsafe object
https://www.interviewbit.com/hibernate-interview-questions/ 64/65
3/25/23, 11:21 PM Hibernate Interview Questions (2023) - InterviewBit

It is the primary interface for the persistence service


It represents a single unit-of-work with the database

https://www.interviewbit.com/hibernate-interview-questions/ 65/65

You might also like