在hibernate3中,使用了c3p0连接池,尝试了多种办法取得connection对象,以下两种可以使用。




Java代码 



Connection conn;  

// 方法1:hibernate4中将要废弃这个方法
conn = session.connection();

// 方法2:这个方法也可以用,速度稍慢
SessionFactoryImplementor sessionFactory = (SessionFactoryImplementor)new Configuration().configure().buildSessionFactory();
conn = sessionFactory.getConnectionProvider().getConnection();

//方法:3
ConnectionProvider cp =((SessionFactoryImplementor)sessionFactory).getConnectionProvider();
cp.getConnection();


 


按hibernate的计划,4.0开始将除去Session.connection()这个方法,所以还是最好不要使用它了。

官方的替代方法是用Session.doWork();

如:



Java代码 




getSession().doWork(  
new Work() {
public void execute(Connection connection) {
// 这里已经得到connection了,可以继续你的JDBC代码。
// 注意不要close了这个connection。
}
}
);


 

另外一个方法:

 



package com.trendcom.base.util;

import java.sql.Connection;
import java.sql.SQLException;

import javax.sql.DataSource;

import org.hibernate.SessionFactory;
import org.springframework.orm.hibernate4.SessionFactoryUtils;
import org.springframework.web.context.ContextLoaderListener;

public class DataSourceUtil {

private static SessionFactory sessionFactory=null;

static{
sessionFactory=(SessionFactory) ContextLoaderListener.getCurrentWebApplicationContext().getBean("sessionFactory");
}


public static Connection getConnection(){
try {
return getDataSource().getConnection();
} catch (SQLException e) {
e.printStackTrace();
}
return null;
}


public static SessionFactory getSessionFactory() {
return sessionFactory;
}

public static void setSessionFactory(SessionFactory sessionFactory) {
DataSourceUtil.sessionFactory = sessionFactory;
}


private static DataSource getDataSource() {
return SessionFactoryUtils.getDataSource(getSessionFactory());
}

}