DataSource ds=null;
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了清水免費(fèi)建站歡迎大家使用!
Connection con=null;
PreparedStatement ps=null;
ResultSet rs=null;
String username=null;
try{
//實(shí)現(xiàn)數(shù)據(jù)連接池
Context ctx=new InitialContext();
ds=(DataSource)ctx.lookup("java:comp/env/jdbc/userInfo");
}catch(NamingException ne){ne.printStackTrace();}
try{
con=ds.getConnection();
String sql="select * from guestbook order by gst_time desc";
st=con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_READ_ONLY);
rs=st.executeQuery(sql);
。。。。。。
。。。
}
在這段代碼中
Context ctx=new InitialContext();
ds=(DataSource)ctx.lookup("java:comp/env/jdbc/userInfo");就是連接池代碼。
它是讀取配置文件(Context.xml)中數(shù)據(jù)的。
以下是配置文件:
Context path="/WebModule1" docBase="E:\Home\WebModule1" reloadable="true"
Resource name="jdbc/userInfo" auth="Container" type="javax.sql.DataSource"
maxActive="100" maxIdle="30" maxWait="10000" username="sa" password="bye0406"
driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"
url="jdbc:microsoft:sqlserver://localhost:1433;databasename=userInfo" /
/Context
path和docBase中的路徑根據(jù)自己需要配置路徑。該路徑是WEB應(yīng)用程序的路徑。driverClassName和url是連接數(shù)據(jù)庫的驅(qū)動(dòng)類和連接的URL,是根據(jù)你使用的哪種數(shù)據(jù)庫而定。
以下是四種數(shù)據(jù)庫的配制驅(qū)動(dòng):
驅(qū)動(dòng)
SQL Server 2000
類名:com.microsoft.jdbc.sqlserver.SQLServerDriver
URL:jdbc:microsoft:sqlserver://localhost:1433;databasename=pubs
Oracle
類名:oracle.jdbc.driver.OracleDriver
URL:jdbc:oracle:thin:@localhost:152:ORCL
Mysql
類名:com.mysql.jdbc.Driver
URL:jdbc:mysql://localhost:3306/databasename
JDBC-ODBC
類名:sun.jdbc.odbc.JdbcOdbcDriver
URL:jdbc:odbc:datasource_name;
用c3po來創(chuàng)建數(shù)據(jù)庫連接池,
1.到網(wǎng)絡(luò)上下載c3p0-0.9.0.4.jar包,導(dǎo)入工程;(注意以下方法只能用于web服務(wù)).
2.找出web服務(wù)器中conf目錄下的centent.xml,在里面加上以下配置
Resource auth="Container"
description="DB Connection"
driverClass="com.mysql.jdbc.Driver"
maxPoolSize="4"
minPoolSize="2"
acquireIncrement="1"
name="jdbc/TestDB"
user="root"
password="root"
factory="org.apache.naming.factory.BeanFactory"
type="com.mchange.v2.c3p0.ComboPooledDataSource"
jdbcUrl="jdbc:mysql://localhost:3306/自己的數(shù)據(jù)庫名?autoReconnect=true" /
3.java獲取連接池的代碼;
import java.sql.Connection;
import java.sql.SQLException;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
public class DBUtils {
static InitialContext ic;
static DataSource ds;
static{
try {
ic = new InitialContext();
ds = (DataSource)ic.lookup("java:comp/env/jdbc/TestDB");
} catch (NamingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static Connection getCon() {
try {
return ds.getConnection();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}
}
}
通過以上代碼,即可獲取連接池中的連接.
數(shù)據(jù)庫連接池的好處是不言而喻的,現(xiàn)在大部分的application
server都提供自己的數(shù)據(jù)庫連接池方案,此時(shí),只要按照application server的文檔說明,正確配置,即可在應(yīng)用中享受到數(shù)據(jù)庫連接池的好處。
但是,有些時(shí)候,我們的應(yīng)用是個(gè)獨(dú)立的java
application,并不是普通的WEB/J2EE應(yīng)用,而且是單獨(dú)運(yùn)行的,不要什么application
server的配合,這種情況下,我們就需要建立自己的數(shù)據(jù)庫連接池方案了。
1、 DBCP
DBCP是Apache的一個(gè)開源項(xiàng)目:
commons.dbcp
DBCP依賴Apache的另外2個(gè)開源項(xiàng)目
commons.collections和commons.pool
dbcp包,目前版本是1.2.1:
pool包,目前版本是1.3:,
common-collections包:
下載這些包并將這些包的路徑添加到classpath中就可以使用dbcp做為項(xiàng)目中的數(shù)據(jù)庫連接池使用了。
在建立我們自己的數(shù)據(jù)庫連接池時(shí),可以使用xml文件來傳入需要的參數(shù),這里只使用hard
code的方式來簡單介紹,所有需要我們自己寫的代碼很少,只要建立一個(gè)文件如下:
import
org.apache.commons.dbcp.BasicDataSource;
import
org.apache.commons.dbcp.BasicDataSourceFactory;
import
java.sql.SQLException;
import java.sql.Connection;
import
java.util.Properties;
public class ConnectionSource {
private static BasicDataSource dataSource =
null;
public ConnectionSource() {
}
public static void init() {
if (dataSource != null) {
try
{
dataSource.close();
} catch (Exception e)
{
}
dataSource = null;
}
try {
Properties p = new
Properties();
p.setProperty("driverClassName",
"oracle.jdbc.driver.OracleDriver");
p.setProperty("url",
"jdbc:oracle:thin:@192.168.0.1:1521:testDB");
p.setProperty("password", "scott");
p.setProperty("username",
"tiger");
p.setProperty("maxActive", "30");
p.setProperty("maxIdle", "10");
p.setProperty("maxWait",
"1000");
p.setProperty("removeAbandoned",
"false");
p.setProperty("removeAbandonedTimeout",
"120");
p.setProperty("testOnBorrow", "true");
p.setProperty("logAbandoned", "true");
dataSource = (BasicDataSource)
BasicDataSourceFactory.createDataSource(p);
} catch (Exception e) {
}
}
public static synchronized Connection
getConnection() throws SQLException {
if (dataSource == null) {
init();
}
Connection conn = null;
if (dataSource != null) {
conn = dataSource.getConnection();
}
return conn;
}
}
接下來,在我們的應(yīng)用中,只要簡單地使用ConnectionSource.getConnection()就可以取得連接池中的數(shù)據(jù)庫連接,享受數(shù)據(jù)庫連接帶給我們的好處了。當(dāng)我們使用完取得的數(shù)據(jù)庫連接后,只要簡單地使用connection.close()就可把此連接返回到連接池中,至于為什么不是直接關(guān)閉此連接,而是返回給連接池,這是因?yàn)閐bcp使用委派模型來實(shí)現(xiàn)Connection接口了。
在使用Properties來創(chuàng)建BasicDataSource時(shí),有很多參數(shù)可以設(shè)置,比較重要的還有:
testOnBorrow、testOnReturn、testWhileIdle,他們的意思是當(dāng)是取得連接、返回連接或連接空閑時(shí)是否進(jìn)行有效性驗(yàn)證(即是否還和數(shù)據(jù)庫連通的),默認(rèn)都為false。所以當(dāng)數(shù)據(jù)庫連接因?yàn)槟撤N原因斷掉后,再從連接池中取得的連接,實(shí)際上可能是無效的連接了,所以,為了確保取得的連接是有效的,
可以把把這些屬性設(shè)為true。當(dāng)進(jìn)行校驗(yàn)時(shí),需要另一個(gè)參數(shù):validationQuery,對(duì)oracle來說,可以是:SELECT COUNT(*) FROM
DUAL,實(shí)際上就是個(gè)簡單的SQL語句,驗(yàn)證時(shí),就是把這個(gè)SQL語句在數(shù)據(jù)庫上跑一下而已,如果連接正常的,當(dāng)然就有結(jié)果返回了。
還有2個(gè)參數(shù):timeBetweenEvictionRunsMillis 和
minEvictableIdleTimeMillis,
他們兩個(gè)配合,可以持續(xù)更新連接池中的連接對(duì)象,當(dāng)timeBetweenEvictionRunsMillis
大于0時(shí),每過timeBetweenEvictionRunsMillis
時(shí)間,就會(huì)啟動(dòng)一個(gè)線程,校驗(yàn)連接池中閑置時(shí)間超過minEvictableIdleTimeMillis的連接對(duì)象。
還有其他的一些參數(shù),可以參考源代碼。
2、
C3P0:
C3P0是一個(gè)開放源代碼的JDBC連接池,C3PO
連接池是一個(gè)優(yōu)秀的連接池,推薦使用。C3PO實(shí)現(xiàn)了JDBC3.0規(guī)范的部分功能,因而性能更加突出,包括了實(shí)現(xiàn)jdbc3和jdbc2擴(kuò)展規(guī)范說明的Connection 和Statement 池的DataSources 對(duì)象。
下載地址:
package
com.systex.utils.web;
import java.beans.PropertyVetoException;
import
java.sql.Connection;
import java.sql.SQLException;
import
javax.sql.DataSource;
import
com.mchange.v2.c3p0.ComboPooledDataSource;
public class C3PODataSource {
private static
ComboPooledDataSource dataSource = null;
private static final String driver
= "com.mysql.jdbc.Driver";
private static final String url =
"jdbc:mysql://localhost:3306/wyd";
private static final String userName =
"root";
private static final String password = "root";
public static DataSource getDataSource() {
if
(dataSource == null) {
dataSource = new ComboPooledDataSource();
try
{
dataSource.setDriverClass(driver);
} catch (PropertyVetoException
e) {
System.out.println("DataSource Load Driver
Exception!!");
e.printStackTrace();
}
dataSource.setJdbcUrl(url);
dataSource.setUser(userName);
dataSource.setPassword(password);
//
設(shè)置連接池最大連接容量
dataSource.setMaxPoolSize(20);
//
設(shè)置連接池最小連接容量
dataSource.setMinPoolSize(2);
//
設(shè)置連接池最大statements對(duì)象容量
dataSource.setMaxStatements(100);
}
return
dataSource;
}
public static Connection getConnection() throws
SQLException {
return
C3PODataSource.getDataSource().getConnection();
}
}
3、 Proxool
這是一個(gè)Java SQL
Driver驅(qū)動(dòng)程序,提供了對(duì)你選擇的其它類型的驅(qū)動(dòng)程序的連接池封裝??梢苑浅:唵蔚囊浦驳浆F(xiàn)存的代碼中。完全可配置??焖?,成熟,健壯。可以透明地為你現(xiàn)存的JDBC驅(qū)動(dòng)程序增加連接池功能。
官方網(wǎng)站:
下載地址:
網(wǎng)站欄目:java數(shù)據(jù)庫連接池代碼 java druid數(shù)據(jù)庫連接池
網(wǎng)頁路徑:http://jinyejixie.com/article36/dosgosg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)、企業(yè)網(wǎng)站制作、品牌網(wǎng)站建設(shè)、軟件開發(fā)、微信公眾號(hào)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容