-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathHibernateOracleConnect.java
executable file
·112 lines (99 loc) · 3.74 KB
/
HibernateOracleConnect.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package bc.connection.oracle;
import java.sql.Connection;
import java.util.HashMap;
import java.util.Properties;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
public class HibernateOracleConnect {
private SessionFactory field_session_factory;
/** ïîëó÷èòü Properties äëÿ êîíôèãóðèðîâàíèÿ AnnotationConfiguration
* @param path URL ê Oracle
* @param login ëîãèí
* @param password ïàðîëü
* @param pool_count ðàçìåð ïóëà ñîåäèíåíèé
* */
private Properties getPropertiesConfiguration(String path,
String login,
String password,
Integer pool_count){
Properties properties=new Properties();
properties.setProperty("hibernate.connection.driver_class", "oracle.jdbc.driver.OracleDriver");
properties.setProperty("hibernate.connection.url",path);
properties.setProperty("hibernate.connection.username", login);
properties.setProperty("hibernate.connection.password", password);
properties.setProperty("hibernate.connection.pool_size", pool_count.toString());
properties.setProperty("hibernate.dialect", "org.hibernate.dialect.OracleDialect");
properties.setProperty("hibernate.show_sql", "true");
properties.setProperty("hibernate.cache.provider_class", "org.hibernate.cache.NoCacheProvider");
properties.setProperty("hbm2ddl.auto", "update");
//properties.setProperty("current_session_context_class", "thread");
return properties;
}
/** îáúåêò, êîòîðûé ïîëó÷àåò ñåññèè
* @param path of connection (jdbc:oracle:thin:@192.168.15.254:1521:demo)
* @param login ëîãèí
* @param password ïàðîëü
* @param pool_size ðàçìåð ïóëà
* */
public HibernateOracleConnect(String path,
String login,
String password,
int pool_size){
try{
AnnotationConfiguration aconf = new AnnotationConfiguration();
// ìîæíî ñîçäàòü Properties
Integer poolSize;
if(pool_size<0){
poolSize=new Integer(0);
}else{
poolSize=new Integer(pool_size);
}
aconf.setProperties(getPropertiesConfiguration(path,
login,
password,
poolSize));
// äîáàâèòü âñå POJO êëàññû
//aconf.addAnnotatedClass(TablePurchasesInt.class);
this.field_session_factory=aconf.buildSessionFactory();
}catch(Exception ex){
System.out.println("Except:"+ex.getMessage());
}
}
public Session getSession(){
try{
return this.field_session_factory.openSession();
}catch(NullPointerException ex){
return null;
}
}
/** çàêðûòü ñîåäèíåíèå ñ Hibernate*/
public void close(){
if(this.field_session_factory!=null){
this.field_session_factory.close();
this.field_session_factory=null;
}
}
public void finalize(){
if(this.field_session_factory!=null){
this.field_session_factory.close();
}
}
private HashMap<Connection,Session> field_session_connection=new HashMap<Connection,Session>();
/** ïîëó÷èòü Connection èç POOL */
@SuppressWarnings("deprecation")
public Connection getConnection(){
Session session=this.getSession();
Connection connection=session.connection();
this.field_session_connection.put(connection, session);
return connection;
}
/** çàêðûòü Connection */
public void closeConnection(Connection connection){
Session session_for_close=this.field_session_connection.get(connection);
try{
connection.close();
}catch(Exception ex){};
session_for_close.close();
}
}