
Quick Contact
Java Tutorial
- What is Java?
- History of Java
- Hello Java Program
- Features of Java
- Basic Syntax
- Java Setup
- Data Types in Java
- Java Variables
- Operators in Java
- JVM
- Java If-else Statement
- Switch Case Statement
- Java Loops
- Do-While Loop
- Java While Loop
- Continue Statement
- Break Statement in Java
- Constructors in Java
- Oops Concept in Java
- Features of OOPs
- Inheritance
- Exeception handeling
- Aggregation (HAS-A relationship) in Java
- Method Overriding in Java
- Method Overloading
- Java Static Keyword
- Java This Keyword
- Java Final Keyword
- Polymorphism
- Static Binding and Dynamic Binding
- Abstract class in Java
- Access Modifiers in Java
- Difference between abstract class and interface
- Interface in Java
- Garbage Collection in Java
- Java Package
- Encapsulation
- Serialization and Deserialization in Java
- Java Inner Classes
- Java Applets
- Multithreading in Java
- Thread Priorities in Java
- Thread Creation
- Inter Thread Communication
- Wrapper Classes in Java
- Java Input Output
- Java AWT Introduction
- Java Layout Manager
- Java Layout Policy
- Java AWT Events
- Collection Framework
- Collection Framework List Interface
- Swing in Java
- Swing Utility Classes
- Swing Layout Managers
- Java JDBC
- Hibernate Framework Overview – Architecture and Basics
Springboot
- Spring Environment Setup
- Spring Boot CRUD REST API Project using IntelliJ IDEA | Postman | MySQL
- Dockerizing Spring Boot Application | Spring Boot Docker Tutorial
- spring-boot-restapidocumentation with swagger
- Spring Boot HttpClient Overview
- Apache HttpClient POST HTTP Request Example
- Apache HttpClient PUT HTTP Request Example
- Apache HttpClient DELETE HTTP Request Example
- Apache HttpClient HTML Form POST Request Example
- Spring Boot JSP Exampl
- Deploying Spring Boot WAR file with JSP to Tomcat
- Spring Boot Annotations
- Spring Core Annotations
- Spring MVC Annotations with Examples
- Spring Scheduling Annotations
- Spring - Java-based Container Configuration
- Spring Java Based Configuration Example
Hibernate
- Hibernate 5 hello world
- Hibernate- One to One Unidirectional Mapping Annotation Example
- Hibernate - Batch Processing
- Hibernate - Interceptors
- Hibernate 5 - Create, Read, Update and Delete (CRUD) Operations Example
- Hibernate Transaction Management
- Hibernate One to Many Unidirectional Mapping Example
- Hibernate One to Many Bidirectional Mapping Example
- Hibernate Many to Many Annotation Mapping Example
- Hibernate Primary KeyJoin Column
- Hibernate First Level Cache with Example
- Hibernate XML Configuration Example with Maven + Eclipse + MySQL Database
- Hibernate Java Configuration Example
- JPA 2 with Hibernate 5 Bootstrapping Example
- JPA and Hibernate Cascade Types
- Hibernate/JPA - Primary Key Generation
- Hibernate 5 - Enum Type Mapping Example
- Hibernate Component Mapping
- Hibernate Object States – Transient,Persistent and Detached
- Hibernate 5 - Save an Entity Example
- Hibernate 5 - Persist an Entity Example
- Hibernate 5 - saveOrUpdate() Method Example
- Hibernate 5 - get(), load() and byId() Method Examples
- Hibernate 5 - merge() Example
- Hibernate 5 - Delete or Remove an Entity Example
- Hibernate 5 - load() Method Example
- Hibernate Session Interface Methods
- Hibernate Session.clear() Method Example
- Introduction Of Java strutes to Architecture
- Struts 2 - Architecture
- Struts 2 - Configuration Files
- Struts 2 - Actions
- Struts 2 - Interceptors
- Struts 2 - Results & Result Types
- Struts 2 - Value Stack/OGNL
- Struts 2 - File Uploading
- Struts 2 - Database Access
- Struts 2 - Validations Framework
JAVA FX
- JavaFX Tutorial
- Introduction to JavaFX Pane
- JavaFX Popup
- JavaFX group
- JavaFX Controller
- JavaFX Gradient Color
- JavaFXAnchorPane
- JavaFXTabPane
- JavaFX Scene
- JavaFX Stage
- JavaFXWebView
- JavaFX Timeline
- JavaFX Timer
- JavaFX Image
- JavaFX Background
- JavaFX dialog
- JavaFX Font
- JavaFXTextArea
- JavaFXObservableList
- JavaFX GUI
- JavaFX FXML
- JavaFXEventHandler
- JavaFXGradle
- JavafxScrollpane
- JavaFXAPI
The General Steps Needed to Integrate and Configure Hibernate
The following steps are used to create simple hibernate applications:
- Identify the POJOs that have a database representation.
- Identify which properties of those POJOs need to be persisted.
- Annotate each of the POJOs to map your Java object’s properties to columns in a database table.
- Create the database schema using the schema export tool, use an existing database, or create your own database schema.
- Add the Hibernate Java libraries to your application’s classpath.
- Create a Hibernate XML configuration file that points to your database and your mapped classes.
- In your Java application, create a Hibernate Configuration object that references your XML configuration file.
- Also in your Java application, build a Hibernate SessionFactory object from the Configuration object.
- Retrieve the Hibernate Session objects from the SessionFactory, and write your data access logic for your application (create, retrieve, update, and delete).
Development Steps
- Create a Simple Maven Project
- Project Directory Structure
- Add jar Dependencies to pom.xml
- Creating the JPA Entity Class(Persistent class)
- Create a Hibernate configuration file – hibernate.cfg.xml
- Create a Hibernate utility class
- Create the Main class and Run an Application
Project Directory Structure
The project directory structure for your reference –

Add jar Dependencies to pom.xml
< project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> < modelVersion>4.0.0< /modelVersion> < parent> < groupId>net.javaguides.hibernate< /groupId> < artifactId>hibernate-tutorial< /artifactId> < version>0.0.1-SNAPSHOT< /version> < /parent> < artifactId>hibernate-xml-config-example< /artifactId> < properties> < project.build.sourceEncoding>UTF-8< /project.build.sourceEncoding> < /properties> < dependencies> < !-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --> < dependency> < groupId>mysql< /groupId> < artifactId>mysql-connector-java< /artifactId> < version>8.0.13< /version> < /dependency> < !-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core --> < dependency> < groupId>org.hibernate< /groupId> < artifactId>hibernate-core< /artifactId> < version>5.3.7.Final< /version> < /dependency> < /dependencies> < build> < sourceDirectory>src/main/java< /sourceDirectory> < plugins> < plugin> < artifactId>maven-compiler-plugin< /artifactId> < version>3.5.1< /version> < configuration> < source>1.8< /source> < target>1.8< /target> < /configuration> < /plugin> < /plugins> < /build> < /project>
Creating the JPA Entity Class(Persistent class)
Let’s create a Student persistent class that is mapped to a database “student” table.
A simple persistent class should follow some rules:
-
A no-arg constructor:
: It is recommended that you have a default constructor at least package visibility so that hibernate can create the instance of the Persistent class by newInstance() method.
-
Provide an identifier property:
It is better to assign an attribute as id. This attribute behaves as a primary key in a database.
-
Declare getter and setter methods:
The Hibernate recognizes the method by getter and setter method names by default.
-
Prefer non-final class:
Hibernate uses the concept of proxies, that depends on the persistent class. The application programmer will not be able to use proxies for lazy association fetching.
Create a Student entity class under net.javaguides.hibernate.entity package as follows.
packagenet.ducatindia.hibernate.entity; importjavax.persistence.Column; importjavax.persistence.Entity; importjavax.persistence.GeneratedValue; importjavax.persistence.GenerationType; importjavax.persistence.Id; importjavax.persistence.Table; @Entity @Table(name="student") publicclassStudent { @Id @GeneratedValue(strategy=GenerationType.IDENTITY) @Column(name="id") privateint id; @Column(name="first_name") privateStringfirstName; @Column(name="last_name") privateStringlastName; @Column(name="email") privateString email; publicStudent() { } publicStudent(StringfirstName, StringlastName, Stringemail) { this.firstName=firstName; this.lastName=lastName; this.email= email; } publicintgetId() { return id; } publicvoidsetId(intid) { this.id = id; } publicStringgetFirstName() { returnfirstName; } publicvoidsetFirstName(StringfirstName) { this.firstName=firstName; } publicStringgetLastName() { returnlastName; } publicvoidsetLastName(StringlastName) { this.lastName=lastName; } publicStringgetEmail() { return email; } publicvoidsetEmail(Stringemail) { this.email= email; } @Override publicStringtoString() { return"Student [id="+ id +", firstName="+firstName+", lastName="+lastName+", email="+ email +"]"; } }
-
Create a Hibernate configuration file – hibernate.cfg.xml
The configuration file contains information about the database and mapping file. Conventionally, its name should be hibernate.cfg.xml.
Let’s create an XML file named as hibernate.cfg.xml under resources folder and write the following code in it.
< !DOCTYPEhibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> < hibernate-configuration> < session-factory> < !-- JDBC Database connection settings --> < propertyname="connection.driver_class">com.mysql.cj.jdbc.Driver< /property> < propertyname="connection.url">jdbc:mysql://localhost:3306/hibernate_db?useSSL=false</ property> < propertyname="connection.username">root< /property> < propertyname="connection.password">root< /property> < !-- JDBC connection pool settings ... using built-in test pool --> < propertyname="connection.pool_size">1< /property> < !-- Select our SQL dialect --> < propertyname="dialect">org.hibernate.dialect.MySQL5Dialect< /property> < !-- Echo the SQL to stdout --> < propertyname="show_sql">true< /property> < !-- Set the current session context --> < propertyname="current_session_context_class">thread< /property> < !-- Drop and re-create the database schema on startup --> < propertyname="hbm2ddl.auto">create-drop< /property> < !--dbcp connection pool configuration --> < propertyname="hibernate.dbcp.initialSize">5< /property> < propertyname="hibernate.dbcp.maxTotal">20< /property> < propertyname="hibernate.dbcp.maxIdle">10< /property> < propertyname="hibernate.dbcp.minIdle">5< /property> < propertyname="hibernate.dbcp.maxWaitMillis">-1< /property> < mappingclass="net.javaguides.hibernate.entity.Student" /> < /session-factory> < /hibernate-configuration>
-
Create a Hibernate utility Class
Create a helper class to bootstrap hibernate SessionFactory. In most Hibernate applications, the SessionFactory should be instantiated once during application initialization. The single instance should then be used by all code in a particular process, and any Session should be created using this single SessionFactory.
The SessionFactory is thread-safe and can be shared; a Session is a single-threaded object. Let’s create HibernateUtil class to configure singleton SessionFactory and use throughout the application.
The bootstrapping API is quite flexible, but in most cases, it makes the most sense to think of it as a 3 step process:
- Build the StandardServiceRegistry
- Build the Metadata
- Use those 2 to build the SessionFactory
packagenet.ducatindia.hibernate.util; importorg.hibernate.SessionFactory; importorg.hibernate.boot.Metadata; importorg.hibernate.boot.MetadataSources; importorg.hibernate.boot.registry.StandardServiceRegistry; importorg.hibernate.boot.registry.StandardServiceRegistryBuilder; publicclassHibernateUtil { privatestaticStandardServiceRegistry registry; privatestaticSessionFactorysessionFactory; publicstaticSessionFactorygetSessionFactory() { if (sessionFactory==null) { try { // Create registry registry=newStandardServiceRegistryBuilder().configure().build(); // Create MetadataSources MetadataSources sources =newMetadataSources(registry); // Create Metadata Metadatametadata=sources.getMetadataBuilder().build(); // Create SessionFactory sessionFactory=metadata.getSessionFactoryBuilder().build(); } catch (Exception e) { e.printStackTrace(); if (registry !=null) { StandardServiceRegistryBuilder.destroy(registry); } } } returnsessionFactory; } publicstaticvoidshutdown() { if (registry !=null) { StandardServiceRegistryBuilder.destroy(registry); } } }
-
Create the main App class and Run an Application
Here is main App class which is used to connect MySQL database and persist Student object in database table.
packagenet.ducatindia.hibernate; importjava.util.List; importorg.hibernate.Session; importorg.hibernate.Transaction; importnet.javaguides.hibernate.entity.Student; importnet.javaguides.hibernate.util.HibernateUtil; publicclassApp { publicstaticvoidmain(String[] args) { Studentstudent=newStudent("Ramesh", "Fadatare", "rameshfadatare@javaguides.com"); Student student1 =newStudent("John", "Cena", "john@javaguides.com"); Transactiontransaction=null; try (Sessionsession=HibernateUtil.getSessionFactory().openSession()) { // start a transaction transaction=session.beginTransaction(); // save the student objects session.save(student); session.save(student1); // commit transaction transaction.commit(); } catch (Exception e) { if (transaction !=null) { transaction.rollback(); } e.printStackTrace(); } try (Sessionsession=HibernateUtil.getSessionFactory().openSession()) { List< Student> students =session.createQuery("from Student", Student.class).list(); students.forEach(s ->System.out.println(s.getFirstName())); } catch (Exception e) { if (transaction !=null) { transaction.rollback(); } e.printStackTrace(); } } }
Apply now for Advanced Java Training Course