用Java連線SQL Server2000資料庫
用Java連線SQL Server2000資料庫有多種方法,下面介紹其中最常用的兩種(透過JDBC驅動連線資料庫)。以及連線池。
[@more@]用Java連線SQL Server2000資料庫有多種方法,下面介紹其中最常用的兩種(透過JDBC驅動連線資料庫)。
1. 透過Microsoft的JDBC驅動連線。此JDBC驅動共有三個檔案,分別是mssqlserver.jar、msutil.jar和msbase.jar,可以到微軟的網站去下載(),如果你下載的是,還需要安裝它,安裝後會生成上面的三個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,下載路徑為(),此驅動支援Microsoft SQL Server (6.5, 7.0, 2000 和2005) 和Sybase,並且實現了JDBC3.0,是免費的。
驅動程式名稱:net.sourceforge.jtds.jdbc.Driver(即下面的classforname)
資料庫連線URL: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(){}
/**
*
透過Microsoft JDBC驅動獲得資料庫連線
* @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)
{
ex.printStackTrace();
}
catch (SQLException ex)
{
ex.printStackTrace();
}
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/目錄下,開啟它,找到,並在這一行的前面插入如下程式碼:
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裡面設定全域性訪問的名稱,設定如下: 找到,並在這一行的前面插入如下程式碼: 2. 區域性配置:在$TOMCAT_HOME$/conf/Catalina/localhost/目錄下新建一個xml檔案,該xml檔案要與你釋出的Web 應用目錄名稱相同,假如為webappname.xml,加入以下內容(配置Tomcat的外部虛擬目錄也是在這裡搞掂的,哈!) 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"/> 對於前面兩種方法,呼叫連線池程式碼如下:(其中com.yeno.util.Debug的Debug.log()方法主要用於列印除錯資訊,可以用System.out.println()代替) import java.sql.*; import javax.sql.DataSource; import javax.naming.*; import com.yeno.util.Debug; /** * 資料庫操作管理類,只實現資料庫的連線,關閉和事務處理 * @Aurhor Yeno.hhr * Create Date 2005-12-9 */ public class DataPool { public DataPool(){} /** * 透過Tomcat連線池取得資料庫連線
* @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的配置檔案中呼叫系統的連線池設定,關鍵程式碼摘錄如下:
<!--
-->
Hibernate的具體使用方法,請查閱相關詳細資料。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7258203/viewspace-914038/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- java 資料庫程式設計(一)JDBC連線Sql Server資料庫Java資料庫程式設計JDBCSQLServer
- java連線資料庫Java資料庫
- 用Navicat連線資料庫-資料庫連線(MySQL演示)資料庫MySql
- 本地不安裝oracle,用PL/SQL Developer連線資料庫OracleSQLDeveloper資料庫
- Golang 全域性sql資料庫連線GolangSQL資料庫
- c#連線SQL Server資料庫C#SQLServer資料庫
- [資料庫][SQL]圖解各種連線join資料庫SQL圖解
- 1.3.3. 通過SQL*Plus 連線資料庫SQL資料庫
- PL/SQL Developer連線遠端Oracle資料庫SQLDeveloperOracle資料庫
- Java 資料庫連線的那些事Java資料庫
- Java Druid資料庫連線池+SpringJDBCJavaUI資料庫SpringJDBC
- jmap檢視java程式佔用的資料庫連線數Java資料庫
- 【資料庫資料恢復】sql server資料庫連線失效的資料恢復案例資料庫資料恢復SQLServer
- 使用SQL4Automation讓CodeSYS連線資料庫SQL資料庫
- go 連線資料庫 - GORM學習 - sql查詢Go資料庫ORMSQL
- CDA資料分析師 - SQL資料庫基礎 查詢&連線SQL資料庫
- 連線資料庫資料庫
- OceanBase學習之路8|Java 應用程式連線 OceanBase 資料庫Java資料庫
- Java技術之掌握資料庫連線工具DBUtils的應用Java資料庫
- Python連線三大資料庫MS Sql Server、Oracle、MySQLPython大資料資料庫ServerOracleMySql
- Jtti:連線不上SQL資料庫怎麼解決?JttiSQL資料庫
- 第 67 期 Go database/sql 資料庫連線池分析GoDatabaseSQL資料庫
- Java讀取properties檔案連線資料庫Java資料庫
- 資料庫連線池-Druid資料庫連線池原始碼解析資料庫UI原始碼
- mysqli連線資料庫MySql資料庫
- Mongodb資料庫連線MongoDB資料庫
- Android 連線資料庫Android資料庫
- 連線資料庫-mysql資料庫MySql
- jmeter連線資料庫JMeter資料庫
- Mybatis連線資料庫MyBatis資料庫
- JSP連線資料庫JS資料庫
- JDBC連線資料庫JDBC資料庫
- Flask連線資料庫Flask資料庫
- sql server資料庫錯誤資料恢復(資料庫連線失效,無法附加查詢)SQLServer資料庫資料恢復
- 《四 資料庫連線池原始碼》手寫資料庫連線池資料庫原始碼
- 用SQLyog或Navicat遠端連線資料庫SQL資料庫
- dbForge Studio for SQL Server入門教程:如何連線到資料庫SQLServer資料庫
- 1.3.3.1. 關於連線資料庫的SQL*Plus 工具描述資料庫SQL
- 解決無法連線SQL Server資料庫的方法BWSQLServer資料庫