[Spring] Pure java for Spring-hibernate integration

Keywords: Session JDBC Hibernate Database

First import the corresponding jar package for Spring-hibernate



Then prepare the file for the database connectionHibernate.propertiesAlsoJdbc.properties

Hibernate.propertiesFile: Configure the hibernate dialect and automatic table building

hibernate.dialect=org.hibernate.dialect.H2Dialect
hibernate.hbm2ddl.auto=create

Jdbc.propertiesFile: Configuration of dedicated hibernate connection database

jdbc.driverClassName=org.h2.Driver
jdbc.url=jdbc:h2:tcp://localhost/D:/H2/h2/bin
jdbc.username=sa
jdbc.password=123456


Create entity class Customer to map to table

package cn.qblank.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity // Entity classes are mapped to data tables, and class names are specified without specifying a table name
//@Table
public class Customer {
	@Id
	@GeneratedValue(strategy = GenerationType.IDENTITY)
	private Long id;
	
	private String name;
	private String address;
	private boolean vip;
	
	public Long getId() {
		return id;
	}
	public void setId(Long id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getAddress() {
		return address;
	}
	public void setAddress(String address) {
		this.address = address;
	}
	public boolean isVip() {
		return vip;
	}
	public void setVip(boolean vip) {
		this.vip = vip;
	}
	
	@Override
	public String toString() {
		return "Customer [id=" + id + ", name=" + name + ", address=" + address + ", vip=" + vip + "]";
	}
	
	
}

Write a CustomerDao interface at the dao layer

package cn.qblank.dao;

import cn.qblank.entity.Customer;

public interface CustomerDao {
	void create(Customer customer);
	
	void update(Customer customer);
	
	Customer find(Long id);
	
	void delete(Long id);
}


Implement the class CustomerDao to implement the interface and implement all its methods

package cn.qblank.dao.impl;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import cn.qblank.dao.CustomerDao;
import cn.qblank.entity.Customer;

@Repository
@Transactional
public class CustomerDaoImpl implements CustomerDao {
	@Autowired
	private SessionFactory sessionFactory;
	
	@Override
	public void create(Customer customer) {
		System.out.println("create...");
		Session session = sessionFactory.openSession();
		// crud
		session.save(customer);
	}

	@Override
	public void update(Customer customer) {
		System.out.println("update...");
		Session session = sessionFactory.openSession();
		try {
			session.getTransaction().begin();
			// crud
			session.update(customer);
			
			session.getTransaction().commit();
		} catch (Exception ex) {
			session.getTransaction().rollback();
		} finally {
			session.close();
		}
	}

	@Override
	public Customer find(Long id) {
		return sessionFactory.getCurrentSession().get(Customer.class, id);
		
	}

	@Override
	public void delete(Long id) {
		System.out.println("delete");
		Session session = sessionFactory.getCurrentSession();
		Customer customer = new Customer();
		customer.setId(id);
		session.delete(customer);
	}

}


Create Config Class

package cn.qblank.test;

import javax.sql.DataSource;

import org.hibernate.SessionFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.core.env.Environment;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
import org.springframework.orm.hibernate5.HibernateTransactionManager;
import org.springframework.orm.hibernate5.LocalSessionFactoryBean;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;

@Configuration  //configuration file
@ComponentScan("cn.qblank.dao")  //Scanning dao layer
@PropertySource("classpath:jdbc.properties") //Introducing an external property file to Enviroment
@EnableTransactionManagement
public class Config {
	
	@Bean
	public LocalSessionFactoryBean sessionFactory(DataSource dataSource) {
		LocalSessionFactoryBean factoryBean = new LocalSessionFactoryBean();
		factoryBean.setDataSource(dataSource);
		factoryBean.setPackagesToScan("cn.qblank.entity"); // Automatically scan and register entity classes
		return factoryBean;
	}
	
	
	@Bean                       // Dependent on Environment
	public DataSource dataSource(Environment env) {
		DriverManagerDataSource ds = new DriverManagerDataSource();
		// env.getProperty("someKey") Gets the attribute value
		ds.setDriverClassName(env.getProperty("jdbc.driverClassName"));
		ds.setUrl(env.getProperty("jdbc.url"));
		ds.setUsername(env.getProperty("jdbc.username"));
		ds.setPassword(env.getProperty("jdbc.password"));
		return ds;
	}
	
	//Create Transaction Management Class
	@Bean
	public PlatformTransactionManager transactionManager(SessionFactory sessionFactory){
		HibernateTransactionManager transactionManager=new HibernateTransactionManager();
		transactionManager.setSessionFactory(sessionFactory);
		return transactionManager;
	}
}

Test last

package cn.qblank.test;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;

import cn.qblank.dao.CustomerDao;
import cn.qblank.entity.Customer;

public class Main {
	public static void main(String[] args) {
		AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(Config.class);
		CustomerDao customerDao = context.getBean(CustomerDao.class);
		Customer customer = new Customer();
		customer.setName("Zhao Six");
		customer.setAddress("Changsha, Hunan");
		customer.setVip(true);
		customerDao.create(customer);
//		Customer customer = customerDao.find(1L);
//		System.out.println(customer);
//		customerDao.delete(3l);
		context.close();
	}
}

Run result:



Here we add an exception at the dao layer:

@Override
public void create(Customer customer){
	System.out.println("create...");
	Session session = sessionFactory.getCurrentSession();
	// crud
	session.save(customer);
	throw new RuntimeException("My name is an exception");
}

Then test:

package cn.qblank.test;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;

import cn.qblank.dao.CustomerDao;
import cn.qblank.entity.Customer;

public class Main {
	public static void main(String[] args) {
		AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(Config.class);
		CustomerDao customerDao = context.getBean(CustomerDao.class);
		Customer customer = new Customer();
		customer.setName("Sparrow");
		customer.setAddress("Changsha, Hunan");
		customer.setVip(true);
		customerDao.create(customer);
//		Customer customer = customerDao.find(1L);
//		System.out.println(customer);
//		customerDao.delete(3l);
		context.close();
	}
}



You can see that an error occurred and the transaction rolled back successfully


Posted by mjgdunne on Wed, 08 Jul 2020 07:43:57 -0700