JPA providers, such as Hibernate (or Eclipse Link) rely on reflection to instantiate entity objects during database operations. Hibernate uses the Reflection API to create instance of Entity beans, usually when you call get()
or load()
methods. The method Class.newInstance()
is used for this and it requires no-args constructor.
An empty constructor allows these providers to create instances of your entity class without providing any constructor arguments.
Let's consider an example entity class:
@Entity
public class MyEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
// Empty constructor for JPA
public MyEntity() {
// Default constructor
// Sonarqube recommends to add a descriptive comment here as a good practice
}
// Constructors, getters, setters, and other methods...
}
So if you don't have no-args constructor in entity beans, hibernate will fail to instantiate it, and you will get HibernateException
.
Reflection is powerful, but it's important to be cautious when employing it. If it is possible to perform an operation without using reflection, then it is preferable to avoid using it.
Because reflection involves types that are dynamically resolved, certain Java virtual machine optimizations cannot be performed. Consequently, reflective operations have slower performance than their non-reflective counterparts, and should be avoided in sections of code which are called frequently in performance-sensitive applications.
🔍. Similar posts
The Simple Way to Run a Long Docker Command in Multiline
14 Jan 2025
How to Hard Reset Your Git Repository to 10 Minutes Ago
04 Sep 2024
How to Easily Generate a Java Project Using Maven Command
04 Sep 2024