hibernate实现分表

Hibernate实现分表处理,分表原理基于SQLInterceptor方式实现


import java.util.Date;

import org.hibernate.Session;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.orm.hibernate3.HibernateTemplate;
import org.springframework.stereotype.Component;

@Component
public class TestDAO {
	@Autowired
	@Qualifier("XXXXTemplate")
	private HibernateTemplate template;
	private SQLInterceptor interceptor = new SQLInterceptor("tableName");
	
	public void save(POJO entity){
		Session session = template.getSessionFactory().openSession(interceptor);
		/*分表策略:按月份对数据进行分割*/
		Integer yearMonth = Integer.parseInt(DateUtils.format(new Date(), "yyyyMM"));
		interceptor.setNewTable("tableName_"+yearMonth);
		session.save(entity);
		session.close();
		System.out.println("返回主键ID:" + entity.getId());
	}
}
#HibernateSQL拦截器

import org.hibernate.EmptyInterceptor;
public class SQLInterceptor extends EmptyInterceptor {
	private static final long serialVersionUID = 1637672155224242981L;

	public SQLInterceptor(String table) {
		this.table = table;
	}

	public String table;
	private String newTable;

	public void setNewTable(String newTable) {
		this.newTable = newTable;
	}

	@Override
	public String onPrepareStatement(String sql) {
		if (StringUtils.isNotEmpty(table, newTable)) {
			sql = sql.replaceAll(table, newTable);
		}
		return super.onPrepareStatement(sql);
	}

}

使用JDBC方式获取数据库表生成自增ID

private Integer insert(POJO entity, String table) throws SQLException {
		String insertSQL = "INSERT INTO " + table + " (XXXX)VALUES(?,?)";
		DataSource dataSource = SessionFactoryUtils.getDataSource(getHibernateTemplate().getSessionFactory());
		Connection connection = null;
		PreparedStatement pStatement = null;
		ResultSet resultSet = null;
		try {
			connection = dataSource.getConnection();
			pStatement = connection.prepareStatement(insertSQL, Statement.RETURN_GENERATED_KEYS);//返回数据库生成自增ID
			pStatement.setInt(1, entity.getSId());
			pStatement.setInt(2, entity.getNum());
			pStatement.executeUpdate();
			resultSet = pStatement.getGeneratedKeys();
			if (resultSet.next()) {//获取数据库生成ID
				return resultSet.getInt(1);
			}
		} finally {
			//close()
		}
		return -1;
	}




  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值