欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

將Java程序與數(shù)據(jù)庫進(jìn)行連接的操作方法

 更新時(shí)間:2015年10月10日 16:48:51   投稿:goldensun  
這篇文章主要介紹了將Java程序與數(shù)據(jù)庫進(jìn)行連接的操作方法,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下

一個(gè)網(wǎng)絡(luò)關(guān)系數(shù)據(jù)庫應(yīng)用系統(tǒng)是一個(gè)三層次結(jié)構(gòu)??蛻魴C(jī)與服務(wù)器采用網(wǎng)絡(luò)連接,客戶機(jī)端應(yīng)用程序按通信協(xié)議與服務(wù)器端的數(shù)據(jù)庫程序通信;數(shù)據(jù)庫服務(wù)程序通過SQL命令與數(shù)據(jù)庫管理系統(tǒng)通信。

Java程序與數(shù)據(jù)庫連接方法有兩種。一種是使用JDBC-ODBC橋接器與數(shù)據(jù)庫連接,一種是用純Java的JDBC驅(qū)動(dòng)程序?qū)崿F(xiàn)與數(shù)據(jù)庫連接。
使用JDBC-ODBC 橋接器與數(shù)據(jù)庫連接

Java程序使用JDBC-ODBC 橋接器與數(shù)據(jù)庫連接,Java程序與數(shù)據(jù)庫通信的過程是:
先由數(shù)據(jù)庫應(yīng)用程序向ODBC驅(qū)動(dòng)管理器發(fā)出API調(diào)用,ODBC驅(qū)動(dòng)管理器將這個(gè)調(diào)用轉(zhuǎn)換成向數(shù)據(jù)庫管理系統(tǒng)的ODBC驅(qū)動(dòng)程序調(diào)用,數(shù)據(jù)庫管理系統(tǒng)又將這個(gè)調(diào)用轉(zhuǎn)換成對(duì)操作系統(tǒng)的數(shù)據(jù)輸入/輸出調(diào)用。最后,操作系統(tǒng)從數(shù)據(jù)庫中得到實(shí)際數(shù)據(jù)逐級(jí)返回。

數(shù)據(jù)庫編程首先要設(shè)置數(shù)據(jù)源,在ODBC中設(shè)置數(shù)據(jù)源的步驟如下:
打開Windows控制面板中的管理工具。對(duì)于windows XP:選擇“性能維護(hù)”>>“管理工具”>>“數(shù)據(jù)源(ODBC)”; 對(duì)于windows 2000:選擇“管理工具”>>“數(shù)據(jù)源”。
打開“數(shù)據(jù)源”。出現(xiàn)ODBC數(shù)據(jù)源管理器對(duì)話框,顯示現(xiàn)有的數(shù)據(jù)源名稱。
選擇“用戶DSN”,單擊“添加”按鈕,出現(xiàn)安裝數(shù)據(jù)源驅(qū)動(dòng)程序?qū)υ捒?。Access(*.mdb)數(shù)據(jù)源,單擊“完成”按鈕,出現(xiàn)“創(chuàng)建數(shù)據(jù)源對(duì)話框,鍵入需要?jiǎng)?chuàng)建的數(shù)據(jù)源名,并為創(chuàng)建的數(shù)據(jù)源選擇一個(gè)數(shù)據(jù)庫表。
單擊數(shù)據(jù)庫區(qū)域的“選擇”按鈕,選擇需要的數(shù)據(jù)庫表。當(dāng)需要為數(shù)據(jù)源授權(quán)訪問級(jí)別時(shí),單擊“高級(jí)”按鈕。設(shè)置登錄名和密碼后,單擊“確定”按鈕,完成Access數(shù)據(jù)庫在ODBC管理器中的配置。
如果還沒有數(shù)據(jù)庫表,則需創(chuàng)建一個(gè)數(shù)據(jù)庫表。

數(shù)據(jù)源就是數(shù)據(jù)庫,在設(shè)定了數(shù)據(jù)源的基礎(chǔ)上,Java程序要訪問數(shù)據(jù)庫表,還要建立JDBC-ODBC橋接器,讓程序與數(shù)據(jù)庫連接。以后,程序就可向數(shù)據(jù)庫發(fā)送SQL語句,處理數(shù)據(jù)庫返回的結(jié)果。Java數(shù)據(jù)庫連接JDBC(Java DataBase Connectivity)由一組用Java語言編寫的類和接口組成,JDBC是Java程序與數(shù)據(jù)庫連接API。它能做以下三件事情:與某個(gè)數(shù)據(jù)庫建立連接、向數(shù)據(jù)庫發(fā)送SQL語句和處理數(shù)據(jù)庫返回的結(jié)果。

調(diào)用類方法Class.forName(String s)能建立JDBC-ODBC橋接器。例如,代碼:

  try{
    Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”);
  }catch(Exception e){}


為Java程序加載了驅(qū)動(dòng)程序。
【例】說明與數(shù)據(jù)庫連接的方法connectByJdbcOdbc(),該方法按給定的數(shù)據(jù)庫URL、用戶名和密碼連接數(shù)據(jù)庫,如果連接成功,方法返回連接對(duì)象,連接不成功,則返回空。

public static connection connectByjdbcOdbc(String url, String username, String password){
  Connection con = null;
  try{
    Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");  //加載ODBC驅(qū)動(dòng)程序
  }
  catch (Exception e){
    e.printStackTrace();
    return null; //連接失敗
  }
  try{
    con = DriverManager.getConnection(url, username, password);
  }
  catch (SQLExceotuib e){
    e.printStackTrace();
    return null; //連接不成功
  }
  return con; //連接成功
}

以下代碼是對(duì)connectByJdbcOdbc()方法的一個(gè)調(diào)用,數(shù)據(jù)庫連接成功,彈出數(shù)據(jù)庫連接成功信息窗,否則彈出數(shù)據(jù)庫連接不成功信息窗。

if ((con = connectByJdbcOdbc("jdbc:odbc:redsun", "xia", "1234")) != null){
  JoptionPane.showMessageDialog(null, "數(shù)據(jù)庫連接成功");
  try{
    con.close();
    con = null;
  }
  catch (SOLException e){}
}
else
  JOptionPane.showMessageDialog(null, "數(shù)據(jù)庫連接失敗");

用純Java的JDBC驅(qū)動(dòng)程序?qū)崿F(xiàn)與數(shù)據(jù)庫連接

Java程序也可以用純Java的JDBC驅(qū)動(dòng)程序?qū)崿F(xiàn)與數(shù)據(jù)庫連接。這種方法應(yīng)用較廣泛,但是需要下載相應(yīng)的驅(qū)動(dòng)程序包,因?yàn)椴煌臄?shù)據(jù)庫的連接代碼可能不同,連接不同的數(shù)據(jù)庫,加載的驅(qū)動(dòng)程序也可能不同。例如,連接SQLServer的驅(qū)動(dòng)程序在www.msdn.com網(wǎng)站下載,有3個(gè)包:msbase.jar,mssqlserver.jar和msutil.jar,并要求將這3個(gè)包放在jdk\jre\lib\ext\目錄下,或在CLASSPATH中設(shè)置其放置位置。

使用純Java的JDBC驅(qū)動(dòng)程序?qū)崿F(xiàn)與數(shù)據(jù)庫連接的過程如下:
加載驅(qū)動(dòng)程序。有兩種加載驅(qū)動(dòng)程序的方式:
一各是將驅(qū)動(dòng)程序添加到j(luò)ava.lang.System的屬性jdbc.drivers中。這是一個(gè)DriverManager類加載驅(qū)動(dòng)程序類名的列表,表元用冒號(hào)分隔。
另一種方式是從相關(guān)的網(wǎng)站下載驅(qū)動(dòng)程序后,在程序中利用Class.forName()方法加載指定的驅(qū)動(dòng)程序。例如:

  Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”);


創(chuàng)建指定數(shù)據(jù)庫的URL。數(shù)據(jù)庫的URL對(duì)象類似網(wǎng)絡(luò)的統(tǒng)一資源定位符,其格式是:

  jdbc:subProtocol:subName://hostname:port:Databasename=XXX


其中,subprotocol是某種驅(qū)動(dòng)程序支持的數(shù)據(jù)庫連接機(jī)制; subName是當(dāng)前連接機(jī)制下的具體名稱;hostName是主機(jī)名;port是相應(yīng)的連接端口;DatabaseName是要連接的數(shù)據(jù)庫名稱。例如,以下代碼可以是一個(gè)數(shù)據(jù)庫的URL:

  jdbc:Microsoft:sqlserver://localhost:1433;Databasename=ksinfo


該數(shù)據(jù)庫的URL說明利用miscrosoft提供的機(jī)制,用sqlserve驅(qū)動(dòng),通過1433端口訪問本機(jī)上的ksInfo數(shù)據(jù)庫。
建立連接。驅(qū)動(dòng)程序管理器(DriverManager)的方法getConnection()建立連接。

【例】說明與數(shù)據(jù)庫連接的靜態(tài)方法connectByJdbc(),該方法按給定的數(shù)據(jù)庫URL、用戶名和密碼連接數(shù)據(jù)庫,如果連接成功,方法返回true,連接不成功,則返回false。

public static Connection conectByJdbc(String url, String username, String password){
  Connection con = null;
  try{
    Class.forName( //加載特定的驅(qū)動(dòng)程序
    "com.microsoft.jdbc.sqlserver.SQLServerDriver");
  }
  catch (Exception e){
    e.printStackTrace();
    return null; //連接失敗
  }
  try{
    con = DriverManage.getConnection(url, username, password);
  }
  catch (SQLException e){
    e.printStackTrace();
    return null; //連接失敗
  }
  return con; //連接成功
}

相關(guān)文章

  • 用Maven插件生成Mybatis代碼的實(shí)現(xiàn)方法

    用Maven插件生成Mybatis代碼的實(shí)現(xiàn)方法

    本文主要介紹 Maven插件生成Mybatis代碼,現(xiàn)在做開發(fā)的朋友有好多用Maven 來管理代碼,這里給大家舉個(gè)例子,有需要的同學(xué)可以看下
    2016-07-07
  • 利用Java實(shí)現(xiàn)天氣預(yù)報(bào)播報(bào)功能

    利用Java實(shí)現(xiàn)天氣預(yù)報(bào)播報(bào)功能

    這篇文章主要為大家介紹了如何利用Java語言實(shí)現(xiàn)天氣預(yù)報(bào)播報(bào)功能,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Java有一定的幫助,需要的可以參考一下
    2022-06-06
  • Java自定義長(zhǎng)度可變數(shù)組的操作

    Java自定義長(zhǎng)度可變數(shù)組的操作

    這篇文章主要介紹了Java自定義長(zhǎng)度可變數(shù)組的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • 集合框架(Collections Framework)詳解及代碼示例

    集合框架(Collections Framework)詳解及代碼示例

    這篇文章主要介紹了集合框架(Collections Framework)詳解及代碼示例,文章涉及集合數(shù)組的區(qū)別,collection接口,iterator迭代器,list接口及其用法,LinkedHashSet集合等有關(guān)內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • Java 深入探究講解工廠方法模式

    Java 深入探究講解工廠方法模式

    工廠方法模式(FACTORY METHOD)是一種常用的類創(chuàng)建型設(shè)計(jì)模式,此模式的核心精神是封裝類中變化的部分,提取其中個(gè)性化善變的部分為獨(dú)立類,通過依賴注入以達(dá)到解耦、復(fù)用和方便后期維護(hù)拓展的目的。它的核心結(jié)構(gòu)有四個(gè)角色,分別是抽象工廠、具體工廠、抽象產(chǎn)品、具體產(chǎn)品
    2022-04-04
  • Java實(shí)現(xiàn)花卉管理系統(tǒng)

    Java實(shí)現(xiàn)花卉管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)花卉管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Ribbon單獨(dú)使用,配置自動(dòng)重試,實(shí)現(xiàn)負(fù)載均衡和高可用方式

    Ribbon單獨(dú)使用,配置自動(dòng)重試,實(shí)現(xiàn)負(fù)載均衡和高可用方式

    這篇文章主要介紹了Ribbon單獨(dú)使用,配置自動(dòng)重試,實(shí)現(xiàn)負(fù)載均衡和高可用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 詳解rabbitmq使用springboot實(shí)現(xiàn)fanout模式

    詳解rabbitmq使用springboot實(shí)現(xiàn)fanout模式

    這篇文章主要介紹了rabbitmq使用springboot實(shí)現(xiàn)fanout模式,Fanout特點(diǎn)是發(fā)布與訂閱模式,是一種廣播機(jī)制,它是沒有路由key的模式,需要的朋友可以參考下
    2023-07-07
  • java-流的使用完結(jié)與異常處理機(jī)制(詳解)

    java-流的使用完結(jié)與異常處理機(jī)制(詳解)

    下面小編就為大家?guī)硪黄猨ava-流的使用完結(jié)與異常處理機(jī)制(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • Ajax+Servlet+jsp顯示搜索效果

    Ajax+Servlet+jsp顯示搜索效果

    這篇文章主要為大家詳細(xì)介紹了Ajax+Servlet+jsp顯示搜索效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12

最新評(píng)論