<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    葉明的javablog

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

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

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

    1. 通過(guò)Microsoft的JDBC驅(qū)動(dòng)連接。此JDBC驅(qū)動(dòng)共有三個(gè)文件,分別是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,還需要安裝它,安裝后會(huì)生成上面的三個(gè)jar文件。此JDBC驅(qū)動(dòng)實(shí)現(xiàn)了 JDBC 2.0。
    驅(qū)動(dòng)程序名稱(chēng):com.microsoft.jdbc.sqlserver.SQLServerDriver(即下面的classforname
    數(shù)據(jù)庫(kù)連接URL:jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=dbname(即下面的url

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

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

    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>通過(guò)Microsoft JDBC驅(qū)動(dòng)獲得數(shù)據(jù)庫(kù)連接</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è)置是否有問(wèn)題,步驟如下:

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

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

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

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

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

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

    1. 全局配置(Tomcat里的任何Web應(yīng)用都能使用該配置的連接池):在server.xml里面配置連接池,server.xml文件位于 $TOMCAT_HOME$/conf/目錄下,打開(kāi)它,找到</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全稱(chēng),username為password為數(shù)據(jù)庫(kù)的連接用戶(hù)名和密碼,driverClassName是數(shù)據(jù)庫(kù)驅(qū)動(dòng)名稱(chēng),url是數(shù)據(jù)庫(kù)連接字符串。請(qǐng)按照你的實(shí)際配置進(jìn)行修改。
    配置到這里還沒(méi)有算完成,下面要在context.xml里面設(shè)置全局訪問(wèn)的名稱(chēng),設(shè)置如下:

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

    2. 局部配置:在$TOMCAT_HOME$/conf/Catalina/localhost/目錄下新建一個(gè)xml文件,該xml文件要與你發(fā)布的Web應(yīng)用目錄名稱(chē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>

    對(duì)于前面兩種方法,調(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ù)庫(kù)操作管理類(lèi),只實(shí)現(xiàn)數(shù)據(jù)庫(kù)的連接,關(guān)閉和事務(wù)處理</p>
     * @Aurhor Yeno.hhr
     * Create Date 2005-12-9
     */
    public class DataPool {

     public DataPool(){}
     
     /**
         * <p>通過(guò)Tomcat連接池取得數(shù)據(jù)庫(kù)連接</p>
         * @param no
         * @return Connection 數(shù)據(jù)庫(kù)連接
         * @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ū)動(dòng)的相關(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/目錄下

    還可以用注入方式來(lái)調(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的具體使用方法,請(qǐng)查閱相關(guān)詳細(xì)資料。

    Feedback

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

    2007-12-07 21:22 by wang
    我還沒(méi)用首先感謝!!!

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

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

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

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

    只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 国产AV无码专区亚洲AV毛网站 | 亚洲国产精品无码久久98| 亚洲综合成人婷婷五月网址| 亚洲AV无码专区在线电影成人 | 又粗又大又黑又长的免费视频| 欧洲精品成人免费视频在线观看 | 国产亚洲精品看片在线观看| 亚洲av无码无在线观看红杏| 亚洲国产成a人v在线| 色欲aⅴ亚洲情无码AV蜜桃| 9久热这里只有精品免费| 100部毛片免费全部播放完整| 午夜a级成人免费毛片| 亚洲中文字幕无码永久在线| 久久亚洲AV成人无码国产 | 亚洲色图激情文学| 成人特级毛片69免费观看| 野花香在线视频免费观看大全| 无码区日韩特区永久免费系列| 免费在线观看黄色毛片| 久久噜噜噜久久亚洲va久| 亚洲色大成网站www永久男同 | 国产一区二区三区免费观看在线| 精品免费久久久久久久| 免费国产不卡午夜福在线| 久热综合在线亚洲精品| 亚洲欧美日韩综合久久久久| 中文字幕在线成人免费看| 在线a级毛片免费视频| 久久久久亚洲?V成人无码| 亚洲伦理一二三四| a级毛片免费观看在线| 国产一卡2卡3卡4卡无卡免费视频| 亚洲精品无码激情AV| 亚洲国产精品成人久久久| 一个人看的www免费高清| 波多野结衣免费在线| 国产亚洲一区区二区在线 | 99ri精品国产亚洲| 日韩在线观看视频免费| 免费专区丝袜脚调教视频|