你的問題很難回答啊
創(chuàng)新互聯(lián)是一家專業(yè)提供湖南企業(yè)網(wǎng)站建設,專注與成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設、H5開發(fā)、小程序制作等業(yè)務。10年已為湖南眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進行中。
如果從內(nèi)在原理來講就是一種:先加載驅動程序再獲得連接
如果從操作來講我把他分三種:
1,直接在你的代碼中用代碼寫出加載驅動和獲得連接的代碼
2,在windows的數(shù)據(jù)源中配置一個數(shù)據(jù)源,這種方法一般不用
3,如果是網(wǎng)站開發(fā)可以在web應用的web.xml中配置一個連接池,用時直接從池中獲得連接.
java與數(shù)據(jù)庫的連接都是通過JDBC接口實現(xiàn)的你如果要問的是JDBC的種類的話你可以查數(shù)就4類
1,jdbc-odbc橋
2,jdbc-native方法
3,jdbc-網(wǎng)絡
4,jdbc驅動
你如果問JDBC具體有哪些,那只能告訴你有幾種數(shù)據(jù)庫就有幾種JDBC.
DataSource ds=null;
Connection con=null;
PreparedStatement ps=null;
ResultSet rs=null;
String username=null;
try{
//實現(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應用程序的路徑。driverClassName和url是連接數(shù)據(jù)庫的驅動類和連接的URL,是根據(jù)你使用的哪種數(shù)據(jù)庫而定。
以下是四種數(shù)據(jù)庫的配制驅動:
驅動
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)絡上下載c3p0-0.9.0.4.jar包,導入工程;(注意以下方法只能用于web服務).
2.找出web服務器中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;
}
}
}
通過以上代碼,即可獲取連接池中的連接.
資源池(Resource Pool)
該模式正是為了更好地解決資源的頻繁分配與釋放所造成的問題。
解決該問題,可以采用數(shù)據(jù)庫連接池技術。
數(shù)據(jù)庫連接池是為數(shù)據(jù)庫連接建立一個“緩沖池”。
預先在緩沖池中放入一定數(shù)量的連接,當需要建立數(shù)據(jù)庫連接時,只需從“緩沖池”中取出一個,使用完畢之后再放回去。
可以通過設定連接池最大連接數(shù)來防止系統(tǒng)無盡的與數(shù)據(jù)庫連接。
更為重要的是通過連接池的管理機制監(jiān)視數(shù)據(jù)庫的連接的數(shù)量和使用情況,為系統(tǒng)開發(fā)﹑測試及性能調(diào)整提供有效的依據(jù)