用Java連接SQL Server2000資料庫有多種方法,以下介紹其中最常用的兩種(透過JDBC驅動連接資料庫)。
1. 透過Microsoft的JDBC驅動連線。此JDBC驅動程式共有三個文件,分別是mssqlserver.jar、msutil.jar和msbase.jar,可以到微軟的網站去下載(://www.microsoft.com/downloads/details.aspx?FamilyId=07287B11-0502 -461A-B138-2AA54BFDC03A&displaylang=en),如果你下載的是setup.exe,還需要安裝它,安裝後會產生上面的三個jar檔。此JDBC驅動實現了JDBC 2.0。
驅動程式名稱:com.microsoft.jdbc.sqlserver.SQLServerDriver(即下面的classforname)
資料庫連線URL:jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname(即下面的url)
2. 透過JTDS JDBC Driver連接SQL Server資料庫,此驅動的檔案名稱為jtds-1.2.jar,下載路徑為( http://sourceforge.net/project/showfiles.php?group_id=33291 ),此驅動支援Microsoft SQL Server (6.5, 7.0, 2000 和2005) 和Sybase,實現了JDBC3.0,是免費的。
驅動程式名稱:net.sourceforge.jtds.jdbc.Driver(即下面的classforname)
資料庫連線網址:jdbc:jtds:sqlserver://localhost:1433/dbname(即下面的url)
JDBC連接SQL Server資料庫的Bean代碼網路大把的有,以下摘錄其中的一部分:(請將localhost和1433改成你實際應用中的SQL Server伺服器位址和連接埠號,dbname改成你實際的資料庫名稱)
import java.sql.*;
public class DatabaseConn {
private Connection conn;
private Statement stmt;
private String url = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname";
private String classforname = "com.microsoft.jdbc.sqlserver.SQLServerDriver";
private String uid = "sa";
private String pwd = "password";
public DatabaseConn(){}
/**
* <p>透過Microsoft JDBC驅動取得資料庫連線</p>
* @return Connection
* @exception ClassNotFoundException, SQLException
*/
public Connection getConnection()
{
try
{
Class.forName(classforname);
if (conn == null || conn.isClosed())
conn = DriverManager.getConnection( url, uid, pwd);
}
catch (ClassNotFoundException ex)
catch (SQLException ex)
return conn;
}
}
當然,在做上述工作之前,你得先檢查自己的SQL Server設定是否有問題,步驟如下:
首先打開“命令列窗口”,也就是MS-Dos窗口,輸入
telnet localhost 1433 (當然,用SQL Server所在的伺服器位址取代localhost,連接埠改為SQL Server的實際端口,預設是1433)
如果成功了,表示你的SQL Server是可以連上的,如果沒成功(一般是對於Win2003或WinXP SP2),請進入控制面板,開啟“管理工具”中的“服務”,啟動“SQLSERVERAGENT”服務(當然,你也可以打上SQL Server的SP3補丁包),再繼續上面的操作,應該會成功的。
其次,檢查你的使用者名稱和密碼是否能登陸SQL Server伺服器,當然,最直接的辦法就是打開SQL Server的“查詢分析器”,輸入使用者名稱和密碼,點選確定
如果成功了,表示你的SQL Server登陸設定沒問題,如果失敗了,請打開SQL Server的“企業管理器”,在你註冊的SQL Server伺服器上(也就是左邊的“SQL Server組”下面的那東東)也就是點選右鍵,選擇“屬性”,在“SQL Server (屬性) 設定”對話框中選擇“安全性”,將驗證設為“SQL Server和Windows(S)”,再用查詢分析器測試一次,如果還連接不上,就去檢查你的用戶名和密碼是否有誤。重複測試,直至成功。
如果在JSP中應用連接,當然,除了直接用JDBC外,大夥最熱衷於的莫過於連接池(Pool)了,下面著重介紹一下連接池的幾種用法。
為了方便,先設定JSP容器為Tomcat,因為大家用得比較多
1. 全域設定(Tomcat裡的任何Web應用程式都能使用該設定的連線池):在server.xml裡面設定連線池,server.xml檔案位於$TOMCAT_HOME$/conf/目錄下,開啟它,找到</ GlobalNamingResources>,並在這一行的前面插入如下程式碼:
<Resource
name="jdbc/poolName"
auth="Container"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="10000"
username="sa"
password="password"
driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"
url="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=dbname"/>
注意:name為連接池的全域JNDI全稱,username為password為資料庫的連接使用者名稱和密碼,driverClassName是資料庫驅動名稱,url是資料庫連接字串。請按照你的實際配置進行修改。
配置到這裡還沒算完成,下面要在context.xml裡面設定全域存取的名稱,設定如下:
找到</Context>,並在這一行的前面插入如下程式碼:
<ResourceLink global="jdbc/poolName" name="jdbc/poolName" type="javax.sql.DataSource"/>
2. 局部設定:在$TOMCAT_HOME$/conf/Catalina/localhost/目錄下新建一個xml文件,該xml文件要與你發布的Web應用目錄名稱相同,假如為webappname.xml,加入以下內容(配置Tomcat的外部虛擬目錄也是在這裡搞掂的,哈!
<Context path="/webappname" docBase="d:/webappname" debug="0" reloadable="true" crossContext="true">
<Resource
name="jdbc/poolName"
auth="Container"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="10000"
username="sa"
password="password"
driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"
url="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=dbname"/>
<ResourceLink global="jdbc/poolName" name="jdbc/poolName" type="javax.sql.DataSource"/>
</Context>
對於前面兩種方法,呼叫連接池程式碼如下:(其中com.yeno.util.Debug的Debug.log()方法主要用於列印偵錯訊息,可以用System.out.println()取代)
import java.sql.*;
import javax.sql.DataSource;
import javax.naming.*;
import com.yeno.util.Debug;
/**
* <p>資料庫操作管理類別,只實現資料庫的連線,關閉與事務處理</p>
* @Aurhor Yeno.hhr
* Create Date 2005-12-9
*/
public class DataPool {
public DataPool(){}
/**
* <p>透過Tomcat連線池取得資料庫連線</p>
* @param no
* @return Connection 資料庫連接
* @exception NamingException,SQLException,Exception
*/
public Connection getConnect()
{
Connection conn = null;
try
{
Context intitCtx = new InitialContext();
Context envCtx = (Context)intitCtx.lookup("java:comp/env");
DataSource ds = (DataSource)envCtx.lookup("jdbc/poolName");
conn = ds.getConnection();
}
catch(NamingException nex)
{
Debug.log(this,"getConnect()","No correct environment!");
}
catch(SQLException sqlex)
{
Debug.log(this,"getConnect()","Can't get connection!");
}
return conn;
}
}
在使用上述程式碼之前,必須確保JDBC驅動的相關JAR檔案(Microsoft為mssqlserver.jar、msutil.jar和msbase.jar,JTDS為jtds-1.2.jar)已正確配置,可以將相關JAR檔案拷貝到$TOMCAT_HOME $/common/lib/目錄下,也可以拷貝到$WEB_ROOT$/WEB-INF/lib/目錄下
也可以用注入方式來調用連接池,即在Hibernate的配置文件hibernate.cfg.xml中調用,在JSP容器中配置好連接池以後,再在Hibernate的配置文件中調用系統的連接池設置,關鍵代碼摘錄如下:
<session-factory>
<!--
<property name="jndi.class"></property>
<property name="jndi.url"></property>
-->
<property name="connection.datasource">java:comp/env/jdbc/poolName</property>
<property name="show_sql">false</property>
<property name="dialect">org.hibernate.dialect.SQLServerDialect</property>
</session-factory>
Hibernate的具體使用方法,請查閱相關詳細資料。