葉明的javablog

          java學(xué)習(xí)天堂,個人關(guān)于其他blog:blog.javaworker.cn,歡迎大家訪問
          posts - 64, comments - 50, trackbacks - 0, articles - 3

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

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

          1. 通過Microsoft的JDBC驅(qū)動連接。此JDBC驅(qū)動共有三個文件,分別是mssqlserver.jar、msutil.jar和msbase.jar,可以到微軟的網(wǎng)站去下載(http://www.microsoft.com/downloads/details.aspx?FamilyId=07287B11-0502-461A-B138-2AA54BFDC03A&displaylang=en),如果你下載的是setup.exe,還需要安裝它,安裝后會生成上面的三個jar文件。此JDBC驅(qū)動實(shí)現(xiàn)了 JDBC 2.0。
          驅(qū)動程序名稱:com.microsoft.jdbc.sqlserver.SQLServerDriver(即下面的classforname
          數(shù)據(jù)庫連接URL:jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname(即下面的url

          2. 通過JTDS JDBC Driver連接SQL Server數(shù)據(jù)庫,此驅(qū)動的文件名為jtds-1.2.jar,下載路徑為(http://sourceforge.net/project/showfiles.php?group_id=33291),此驅(qū)動支持Microsoft SQL Server (6.5, 7.0, 2000 和2005) 和Sybase,并且實(shí)現(xiàn)了JDBC3.0,是免費(fèi)的。
          驅(qū)動程序名稱:net.sourceforge.jtds.jdbc.Driver(即下面的classforname
          數(shù)據(jù)庫連接URL:jdbc:jtds:sqlserver://localhost:1433/dbname(即下面的url

          JDBC連接SQL Server數(shù)據(jù)庫的Bean代碼網(wǎng)上大把的有,下面摘錄其中的一部分:(請將localhost和1433改成你實(shí)際應(yīng)用中的SQL Server服務(wù)器地址和端口號,dbname改成你實(shí)際的數(shù)據(jù)庫名

          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驅(qū)動獲得數(shù)據(jù)庫連接</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;  
           }

          }

          當(dāng)然,在做上述工作之前,你得先檢查自己的SQL Server設(shè)置是否有問題,步驟如下:

          首先打開“命令行窗口”,也就是MS-Dos窗口,輸入
          telnet localhost 1433  (當(dāng)然,用SQL Server所在的服務(wù)器地址替代localhost,端口改為SQL Server的實(shí)際端口,默認(rèn)是1433)

          如果成功了,表明你的SQL Server是可以連上的,如果沒成功(一般是對于Win2003或者WinXP SP2),請進(jìn)入控制面板,打開“管理工具”中的“服務(wù)”,啟動“SQLSERVERAGENT”服務(wù)(當(dāng)然,你也可以打上SQL Server的SP3補(bǔ)丁包),再繼續(xù)上面的操作,應(yīng)該會成功的。

          其次,檢查你的用戶名和密碼是否能登陸SQL Server服務(wù)器,當(dāng)然,最直接的辦法就是打開SQL Server的“查詢分析器”,輸入用戶名和密碼,點(diǎn)擊確定

          如果成功了,表明你的SQL Server登陸設(shè)置沒問題,如果失敗了,請打開SQL Server的“企業(yè)管理器”,在你注冊的SQL Server服務(wù)器上(也就是左邊的“SQL Server組”下面的那東東)也就是點(diǎn)擊右鍵,選擇“屬性”,在“SQL Server (屬性) 配置”對話框中選擇“安全性”,將身份驗(yàn)證設(shè)為“SQL Server和Windows(S)”,再用查詢分析器測試一次,如果還連接不上,就去檢查你的用戶名和密碼是否有誤。重復(fù)測試,直至成功。

          如果在JSP中應(yīng)用連接,當(dāng)然,除了直接用JDBC外,大伙最熱衷于的莫過于連接池(Pool)了,下面著重介紹一下連接池的幾種用法。

          為了方便,先設(shè)定JSP容器為Tomcat,因?yàn)榇蠹矣玫帽容^多

          1. 全局配置(Tomcat里的任何Web應(yīng)用都能使用該配置的連接池):在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為數(shù)據(jù)庫的連接用戶名和密碼,driverClassName是數(shù)據(jù)庫驅(qū)動名稱,url是數(shù)據(jù)庫連接字符串。請按照你的實(shí)際配置進(jìn)行修改。
          配置到這里還沒有算完成,下面要在context.xml里面設(shè)置全局訪問的名稱,設(shè)置如下:

          找到</Context>,并在這一行的前面插入如下代碼:
          <ResourceLink global="jdbc/poolName" name="jdbc/poolName" type="javax.sql.DataSource"/>

          2. 局部配置:在$TOMCAT_HOME$/conf/Catalina/localhost/目錄下新建一個xml文件,該xml文件要與你發(fā)布的Web應(yīng)用目錄名稱相同,假如為webappname.xml,加入以下內(nèi)容(配置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>

          對于前面兩種方法,調(diào)用連接池代碼如下:(其中com.yeno.util.Debug的Debug.log()方法主要用于打印調(diào)試信息,可以用System.out.println()代替)

          import java.sql.*;
          import javax.sql.DataSource;
          import javax.naming.*;
          import com.yeno.util.Debug;
          /**
           * <p>數(shù)據(jù)庫操作管理類,只實(shí)現(xiàn)數(shù)據(jù)庫的連接,關(guān)閉和事務(wù)處理</p>
           * @Aurhor Yeno.hhr
           * Create Date 2005-12-9
           */
          public class DataPool {

           public DataPool(){}
           
           /**
               * <p>通過Tomcat連接池取得數(shù)據(jù)庫連接</p>
               * @param no
               * @return Connection 數(shù)據(jù)庫連接
               * @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驅(qū)動的相關(guān)JAR文件(Microsoft為mssqlserver.jar、msutil.jar和msbase.jar,JTDS為jtds-1.2.jar)已正確配置,可以將相關(guān)JAR文件拷貝到$TOMCAT_HOME$/common/lib/目錄下,也可以拷貝到$WEB_ROOT$/WEB-INF/lib/目錄下

          還可以用注入方式來調(diào)用連接池,即在Hibernate的配置文件hibernate.cfg.xml中調(diào)用,在JSP容器中配置好連接池以后,再在Hibernate的配置文件中調(diào)用系統(tǒng)的連接池設(shè)置,關(guān)鍵代碼摘錄如下:

          <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的具體使用方法,請查閱相關(guān)詳細(xì)資料。

          Feedback

          # re: 如何連接SQL Server數(shù)據(jù)庫(Java)   回復(fù)  更多評論   

          2007-12-07 21:22 by wang
          我還沒用首先感謝!!!

          # re: 如何連接SQL Server數(shù)據(jù)庫(Java)   回復(fù)  更多評論   

          2012-11-05 13:58 by 馮利亞
          請問怎樣才能把數(shù)據(jù)庫的兩列數(shù)據(jù)在Jframe的兩個文本框分別顯示

          # java程序中如何連接中文名稱的sql數(shù)據(jù)庫  回復(fù)  更多評論   

          2013-09-17 20:23 by 靈異2000
          設(shè)置url連接sql數(shù)據(jù)庫的數(shù)據(jù)庫名稱如果是中文則在編譯的時候會顯示非法轉(zhuǎn)義字符,請問URL中如何寫中文名稱的數(shù)據(jù)庫名稱

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 青岛市| 富源县| 文成县| 南陵县| 关岭| 海原县| 大冶市| 清水河县| 津南区| 宿迁市| 乐业县| 吉安县| 凌海市| 香港| 大城县| 民勤县| 菏泽市| 屯留县| 兴文县| 盐山县| 颍上县| 墨玉县| 神池县| 大冶市| 古蔺县| 彰化市| 潞城市| 杨浦区| 昌乐县| 贵阳市| 万山特区| 高清| 阜康市| 兰坪| 汉阴县| 宾阳县| 朔州市| 会宁县| 南充市| 泰安市| 乐陵市|