如何連接oracle,mysql, SQL Server數據庫(Java版)

先添加上連接oracle,mysql的驅動路徑和數據庫連接URL:

MySQL:

  final String DBDRIVER = "org.gjt.mm.mysql.Driver" ;
  final String DBURL = "jdbc:mysql://localhost/mldn" ;
  final String DBUSER = "root" ;
  final String DBPASSWORD = "mysqladmin" ;

Oracle:

// 數據庫驅動程序
  final String DBDRIVER = "oracle.jdbc.driver.OracleDriver" ;
  // 數據庫連接地址
  final String DBURL  = "jdbc:oracle:thin:@localhost:1521:mldn" ;
  // 數據庫用戶名
  final String DBUSER  = "scott" ;
  // 數據庫連接密碼
  final String DBPASSWORD = "tiger" ;

 

下面是具體連接SQL Server的講解

轉至:http://dev.csdn.net/author/yeno/3f06bf19b1c147198e00afa0af6bd0dc.html

本例主要講述如何連接SQL Server數據庫,包括相應的驅動及版本和所支持的數據庫版本,還分別講述了JDBC和連接池連接SQL Server的辦法,分析了可能遇到的問題及解決辦法! 轉帖請註明出處並且務必保持內容的完整性,有什麼問題,請直接留言。

 

在CSDN上看到很多朋友問起這個問題,所以想給鄙人曾接觸過的一些方法總結如下:

用Java連接SQL Server2000數據庫有多種方法,下面介紹其中最常用的兩種(通過JDBC驅動連接數據庫)。

1. 通過Microsoft的JDBC驅動連接。此JDBC驅動共有三個文件,分別是mssqlserver.jar、msutil.jar和msbase.jar,可以到微軟的網站去下載(http://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
數據庫連接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(){}
 
 /**
  * <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)
  {
   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/目錄下,打開它,找到</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的具體使用方法,請查閱相關詳細資料。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章