由于我们不是在产品刚开始开发就加入Hibernate的,所以不合适让产品直接使用Hibernate的连接池,只好让Hibernate来使用产品自有的连接池,还好Hibernate已提供了连接池的扩展接口:ConnectionProvider。
Hibernate本身是通过ConnectionProvider接口来实现管理数据库连接的。例如其自带的C3P0ConnectionProvider,ProxoolConnectionProvider等,我们编写一个实现ConnectionProvider接口的类,在Hibernate的配置文件中将相关参数改成该类就OK,相关代码如下:
hibernate.cfg.xml中用以下代码替代之前的数据库连接信息配置:,
[
html]
实现ConnectionManager接口的类:
[java]
package com.shine.sourcedesk.jbpm;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;
import org.hibernate.HibernateException;
import org.hibernate.connection.ConnectionProvider;
import com.shine.framework.jdbc.ConnectionManager;
/**
* 自定义Hibernate连接池,让Hibernate使用产品的ConnectionManager
* @author JiangKunpeng
*
*/
public class NmsConnectionProvider implements ConnectionProvider{
@Override
public void close() throws HibernateException {
}
@Override
public void closeConnection(Connection connection) throws SQLException {
//关闭连接
ConnectionManager.close(connection);
}
@Override
public void configure(Properties properties) throws HibernateException {
}
@Override
public Connection getConnection() throws SQLException {
//使用产品的数据库连接池获取连接
return ConnectionManager.getConnection();
}
@Override
public boolean supportsAggressiveRelease() {
return false;
}