Spring and JPA (Java Persistent API) Integration Application
JPA (Java Persistent API) is the sun specification for persisting objects in the enterprise
application. It is currently used as the replacement for complex entity beans. The implementation of JPA specification are provided by many vendors such as:
- Hibernate
- Toplink
- iBatis
- OpenJPA etc.
Advantage of Spring with JPA
You don't need to write the before and after code for persisting, updating, deleting or searching object such as creating Persistence instance, creating EntityManagerFactory instance, creating
EntityTransaction instance, creating EntityManager instance, commiting EntityTransaction instance and closing EntityManager.
Steps:-
Let's see what are the simple steps for Spring 4.0 and JPA integration:
- First Create a Java Application
- create applicationContext.xml file .
- create User.java file It is the persistent class
- create UserDao.java file .
- create SpringHibernateApplication.java with main method .
For Spring Hibernate application Configuration download jar files by click here
applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:c="http://www.springframework.org/schema/c"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:flow="http://www.springframework.org/schema/webflow-config"
xmlns:jee="http://www.springframework.org/schema/jee"
xmlns:jms="http://www.springframework.org/schema/jms"
xmlns:lang="http://www.springframework.org/schema/lang"
xmlns:osgi="http://www.springframework.org/schema/osgi"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:util="http://www.springframework.org/schema/util"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/webflow-config http://www.springframework.org/schema/webflow-config/spring-webflow-config-2.0.xsd
http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-4.0.xsd
http://www.springframework.org/schema/jms http://www.springframework.org/schema/jms/spring-jms-4.0.xsd
http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-4.0.xsd
http://www.springframework.org/schema/osgi http://www.springframework.org/schema/osgi/spring-osgi-1.2.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd
">
<context:annotation-config />
<context:component-scan base-package="in.jk" />
<tx:annotation-driven
transaction-manager="transactionManager" proxy-target-class="true" />
<bean id="postgresDatasource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url"
value="jdbc:postgresql://localhost:5432/postgres"></property>
<property name="driverClassName"
value="org.postgresql.Driver"></property>
<property name="username" value="postgres"></property>
<property name="password" value="jk123"></property>
</bean>
<bean id="transactionManager"
class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory"
ref="entityManagerFactory" />
</bean>
<bean id="entityManagerFactory"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
p:dataSource-ref="postgresDatasource">
<!-- By Using this no need for classpath:persistance.xml file -->
<property name="packagesToScan" value="in.jk" />
<property name="jpaVendorAdapter">
<bean
class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="showSql" value="true" />
<property name="generateDdl" value="true"></property>
<property name="databasePlatform"
value="org.hibernate.dialect.PostgreSQLDialect" />
</bean>
</property>
</bean>
<bean id="userDao" class="in.jk.UserDao">
</bean>
</beans>
User.java
package in.jk;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name="user_details")
public class User {
@Id
@Column(name="userId")
private int userId;
@Column(name="name")
private String name;
@Column(name="email")
private String email;
// Getters and Setters
@Override
public String toString() {
return "User [userId=" + userId + ", name=" + name + ", email=" + email + "]";
}
}
UserDao.java
package in.jk;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import org.springframework.transaction.annotation.Transactional;
@Transactional
public class UserDao {
@PersistenceContext
EntityManager entityManager;
public void save(User user) {
entityManager.persist(user);
}
public User get(int id) {
return entityManager.find(User.class, id);
}
}
SpringJpaApplication.java
package in.jk;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class SpringJpaApplication {
public static void main(String[] args) {
ApplicationContext context = null;
EntityManagerFactory entityManagerFactory =null;
context=new ClassPathXmlApplicationContext("ApplicationContext.xml");
entityManagerFactory = (EntityManagerFactory)context.getBean("entityManagerFactory");
EntityManager entityManager = entityManagerFactory.createEntityManager();
entityManager.getTransaction().begin();
User user = new User();
user.setUserId(100);
user.setName("JK");
user.setEmail("jk@gmail.com");
// For persist Object
entityManager.persist(user);
System.out.println("User saved in Database ..");
// For find Object
User user1 = entityManager.find(User.class, 100);
System.out.println("User from Database.." + user1);
// For delete Object
entityManager.remove(user1);
System.out.println("User Deleted from Database.." + user1);
entityManager.getTransaction().commit();
System.out.println();
System.out.println("Using Second Way :: ");
System.out.println("Persist and find the Object using Dao with Declative Transatcion");
UserDao userDao = (UserDao) context.getBean("userDao");
User userObj = new User();
userObj.setUserId(101);
userObj.setName("JK");
userObj.setEmail("jk@gmail.com");
// For persist Object
userDao.save(userObj);
// For find Object
User userEntity = userDao.get(101);
System.out.println("User from database.." + userEntity);
System.out.println("Completed Succussfully ....");
}}
Output in Console ....