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

Java編程中使用JDBC API連接數(shù)據(jù)庫和創(chuàng)建程序的方法

 更新時(shí)間:2015年12月24日 09:00:16   投稿:goldensun  
這篇文章主要介紹了Java編程中使用JDBC API連接數(shù)據(jù)庫和創(chuàng)建程序的基本教程,JDBC是一種用于執(zhí)行SQL語句的Java API,可以為多種關(guān)系數(shù)據(jù)庫提供統(tǒng)一訪問需要的朋友可以參考下

JDBC連接數(shù)據(jù)庫

涉及到建立一個(gè)JDBC連接的編程是相當(dāng)簡單的。下面是這些簡單的四個(gè)步驟:

  1. 導(dǎo)入JDBC包: 添加import語句到Java程序?qū)胨璧念愒贘ava代碼中。
  2. 注冊JDBC驅(qū)動(dòng)程序:這一步會(huì)導(dǎo)致JVM加載所需的驅(qū)動(dòng)程序?qū)崿F(xiàn)到內(nèi)存中,因此它可以實(shí)現(xiàn)JDBC請求。
  3. 數(shù)據(jù)庫URL制定:這是創(chuàng)建格式正確的地址指向到要連接的數(shù)據(jù)庫。
  4. 創(chuàng)建連接對象:最后,代碼調(diào)用DriverManager對象的getConnection()方法來建立實(shí)際的數(shù)據(jù)庫連接。

導(dǎo)入JDBC包:
import 語句告訴Java編譯器在哪里可以找到在代碼中引用,并放置在您的源代碼最開始的類。

使用標(biāo)準(zhǔn)的JDBC包,它允許選擇,插入,更新和SQL表中刪除數(shù)據(jù),添加以下進(jìn)口到您的源代碼:

import java.sql.* ; // for standard JDBC programs
import java.math.* ; // for BigDecimal and BigInteger support

注冊JDBC驅(qū)動(dòng)程序:
使用它之前,必須注冊你的驅(qū)動(dòng)程序在程序。注冊驅(qū)動(dòng)程序是由Oracle驅(qū)動(dòng)程序的類文件被加載到內(nèi)存中以便它可以被用作JDBC接口的實(shí)現(xiàn)過程。

需要做這個(gè)注冊只能在你的程序一次??梢酝ㄟ^以下兩種方式之一注冊一個(gè)驅(qū)動(dòng)程序。

方法(I)- Class.forName():
注冊一個(gè)驅(qū)動(dòng)程序中最常用的方法是使用Java的Class.forName()方法來動(dòng)態(tài)加載驅(qū)動(dòng)程序的類文件到內(nèi)存中,它會(huì)自動(dòng)將其注冊。這種方法是可取的,因?yàn)樗试S使驅(qū)動(dòng)注冊配置,便于攜帶。

下面的示例使用Class.forName()來注冊O(shè)racle驅(qū)動(dòng)程序:

try {
  Class.forName("oracle.jdbc.driver.OracleDriver");
}
catch(ClassNotFoundException ex) {
  System.out.println("Error: unable to load driver class!");
  System.exit(1);
}

可以使用getInstance()方法來解決不兼容的JVM,但要編寫了兩個(gè)額外的例外情況如下:

try {
  Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
}
catch(ClassNotFoundException ex) {
  System.out.println("Error: unable to load driver class!");
  System.exit(1);
catch(IllegalAccessException ex) {
  System.out.println("Error: access problem while loading!");
  System.exit(2);
catch(InstantiationException ex) {
  System.out.println("Error: unable to instantiate driver!");
  System.exit(3);
}

方法(二) - DriverManager.registerDriver():
可以用它來注冊一個(gè)驅(qū)動(dòng)程序的第二種方法是使用staticDriverManager.registerDriver()方法。

應(yīng)該,如果使用的是不兼容的JDK JVM,比如微軟提供一個(gè)使用registerDriver()方法。

下面的示例使用registerDriver()來注冊O(shè)racle驅(qū)動(dòng)程序:

try {
  Driver myDriver = new oracle.jdbc.driver.OracleDriver();
  DriverManager.registerDriver( myDriver );
}
catch(ClassNotFoundException ex) {
  System.out.println("Error: unable to load driver class!");
  System.exit(1);
}

數(shù)據(jù)庫URL制定:
當(dāng)加載的驅(qū)動(dòng)程序,可以建立程序中使用DriverManager.getConnection()方法的連接。為方便參考,讓列出了三個(gè)重載DriverManager.getConnection()方法:

  1. getConnection(String url)
  2. getConnection(String url, Properties prop)
  3. getConnection(String url, String user, String password)

在這里,每個(gè)表單需要一個(gè)數(shù)據(jù)庫URL。數(shù)據(jù)庫的URL是指向數(shù)據(jù)庫地址。

制定一個(gè)數(shù)據(jù)庫URL是大多數(shù)用在建立連接相關(guān)。

下表列出了下來流行的JDBC驅(qū)動(dòng)程序名和數(shù)據(jù)庫的URL。

RDBMS JDBC驅(qū)動(dòng)程序的名稱 URL 格式

MySQL com.mysql.jdbc.Driver jdbc:mysql://hostname/ databaseName
ORACLE oracle.jdbc.driver.OracleDriver jdbc:oracle:thin:@hostname:port Number:databaseName
DB2 COM.ibm.db2.jdbc.net.DB2Driver jdbc:db2:hostname:port Number/databaseName
Sybase com.sybase.jdbc.SybDriver jdbc:sybase:Tds:hostname: port Number/databaseName

以URL格式所有高亮的部分是靜態(tài)的,需要改變只剩余部分按照數(shù)據(jù)庫設(shè)置。

創(chuàng)建連接對象: 使用數(shù)據(jù)庫URL的用戶名和密碼:
下面三種形式DriverManager.getConnection()方法來創(chuàng)建一個(gè)連接對象。getConnection()最常用形式要求傳遞一個(gè)數(shù)據(jù)庫URL,用戶名 username和密碼 password:

對URL數(shù)據(jù)庫部分databaseName的值:假設(shè)使用的是Oracle的瘦驅(qū)動(dòng)程序,需要指定一個(gè)主機(jī):端口。

假設(shè)有一臺(tái)主機(jī)TCP/IP地址192.0.0.1 以及主機(jī)名和Oracle監(jiān)聽器被配置為在端口1521,數(shù)據(jù)庫名稱是EMP,然后完整的數(shù)據(jù)庫URL是:

jdbc:oracle:thin:@amrood:1521:EMP

現(xiàn)在,必須調(diào)用適當(dāng)?shù)挠脩裘兔艽a以及getConnection()方法來獲得一個(gè)Connection對象,如下所示:

String URL = "jdbc:oracle:thin:@amrood:1521:EMP";
String USER = "username";
String PASS = "password"
Connection conn = DriverManager.getConnection(URL, USER, PASS);

只使用一個(gè)數(shù)據(jù)庫URL:
第二種形式 DriverManager.getConnection()方法只需要一個(gè)數(shù)據(jù)庫URL:

DriverManager.getConnection(String url);

然而,在這種情況下,數(shù)據(jù)庫的URL,包括用戶名和密碼,并具有以下的一般形式:

jdbc:oracle:driver:username/password@database

所以上面的連接可以創(chuàng)建如下:

String URL = "jdbc:oracle:thin:username/password@amrood:1521:EMP";
Connection conn = DriverManager.getConnection(URL);

使用數(shù)據(jù)庫的URL和一個(gè)Properties對象:
第三種形式DriverManager.getConnection()方法需要一個(gè)數(shù)據(jù)庫URL和一個(gè)Properties對象:

DriverManager.getConnection(String url, Properties info);
Properties對象,保存一組關(guān)鍵字 - 值對。它被用來調(diào)用getConnection()方法時(shí)驅(qū)動(dòng)程序?qū)傩詡鬟f給驅(qū)動(dòng)程序。

為了使通過前面的例子中所做的相同的連接,使用下面的代碼:

import java.util.*;

String URL = "jdbc:oracle:thin:@amrood:1521:EMP";
Properties info = new Properties( );
info.put( "user", "username" );
info.put( "password", "password" );

Connection conn = DriverManager.getConnection(URL, info);

關(guān)閉JDBC連接:
在JDBC程序的結(jié)束,它明確要求關(guān)閉所有的連接到數(shù)據(jù)庫,以結(jié)束每個(gè)數(shù)據(jù)庫會(huì)話。但是,如果忘了,Java垃圾收集器會(huì)關(guān)閉連接時(shí),它會(huì)清除陳舊的對象。

依托垃圾收集,特別是在數(shù)據(jù)庫編程,是非常差的編程習(xí)慣。應(yīng)該總是在關(guān)閉與連接對象關(guān)聯(lián)的close()方法連接的習(xí)慣。

為了確保連接被關(guān)閉,可以在代碼中的finally塊執(zhí)行。 finally塊都會(huì)執(zhí)行,不管是否發(fā)生或也不例外。

要關(guān)閉上面打開的連接,應(yīng)該調(diào)用close()方法,如下所示:

conn.close();
顯式地關(guān)閉連接DBMS節(jié)約資源。


創(chuàng)建JDBC應(yīng)用程序:
有下列涉及構(gòu)建JDBC應(yīng)用程序的六個(gè)步驟:

  1. 導(dǎo)入數(shù)據(jù)包 . 需要包括含有需要進(jìn)行數(shù)據(jù)庫編程的JDBC類的包。大多數(shù)情況下,使用 import java.sql.*  就可以了.
  2. 注冊JDBC驅(qū)動(dòng)程序. 需要初始化驅(qū)動(dòng)程序,可以與數(shù)據(jù)庫打開一個(gè)通信通道。
  3. 打開連接. 需要使用DriverManager.getConnection() 方法創(chuàng)建一個(gè)Connection對象,它代表與數(shù)據(jù)庫的物理連接。
  4. 執(zhí)行查詢 . 需要使用類型聲明的對象建立并提交一個(gè)SQL語句到數(shù)據(jù)庫。
  5. 從結(jié)果集中提取數(shù)據(jù) . 要求使用適當(dāng)?shù)年P(guān)于ResultSet.getXXX()方法來檢索結(jié)果集的數(shù)據(jù)。
  6. 清理環(huán)境. 需要明確地關(guān)閉所有的數(shù)據(jù)庫資源相對依靠JVM的垃圾收集。

示例代碼:
這個(gè)范例的例子可以作為一個(gè)模板,在需要建立JDBC應(yīng)用程序。

基于對環(huán)境和數(shù)據(jù)庫安裝在前面的章節(jié)中做此示例代碼已寫入。

復(fù)制下面的例子FirstExample.java,編譯并運(yùn)行,如下所示:

//STEP 1. Import required packages
import java.sql.*;

public class FirstExample {
  // JDBC driver name and database URL
  static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; 
  static final String DB_URL = "jdbc:mysql://localhost/EMP";

  // Database credentials
  static final String USER = "username";
  static final String PASS = "password";
  
  public static void main(String[] args) {
  Connection conn = null;
  Statement stmt = null;
  try{
   //STEP 2: Register JDBC driver
   Class.forName("com.mysql.jdbc.Driver");

   //STEP 3: Open a connection
   System.out.println("Connecting to database...");
   conn = DriverManager.getConnection(DB_URL,USER,PASS);

   //STEP 4: Execute a query
   System.out.println("Creating statement...");
   stmt = conn.createStatement();
   String sql;
   sql = "SELECT id, first, last, age FROM Employees";
   ResultSet rs = stmt.executeQuery(sql);

   //STEP 5: Extract data from result set
   while(rs.next()){
     //Retrieve by column name
     int id = rs.getInt("id");
     int age = rs.getInt("age");
     String first = rs.getString("first");
     String last = rs.getString("last");

     //Display values
     System.out.print("ID: " + id);
     System.out.print(", Age: " + age);
     System.out.print(", First: " + first);
     System.out.println(", Last: " + last);
   }
   //STEP 6: Clean-up environment
   rs.close();
   stmt.close();
   conn.close();
  }catch(SQLException se){
   //Handle errors for JDBC
   se.printStackTrace();
  }catch(Exception e){
   //Handle errors for Class.forName
   e.printStackTrace();
  }finally{
   //finally block used to close resources
   try{
     if(stmt!=null)
      stmt.close();
   }catch(SQLException se2){
   }// nothing we can do
   try{
     if(conn!=null)
      conn.close();
   }catch(SQLException se){
     se.printStackTrace();
   }//end finally try
  }//end try
  System.out.println("Goodbye!");
}//end main
}//end FirstExample

現(xiàn)在來編譯上面的例子如下:

C:>javac FirstExample.java

當(dāng)運(yùn)行FirstExample,它會(huì)產(chǎn)生以下結(jié)果:

C:>java FirstExample
Connecting to database...
Creating statement...
ID: 100, Age: 18, First: Zara, Last: Ali
ID: 101, Age: 25, First: Mahnaz, Last: Fatma
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal


相關(guān)文章

  • SpringMVC教程之json交互使用詳解

    SpringMVC教程之json交互使用詳解

    本篇文章主要介紹了SpringMVC教程之json使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • Java學(xué)習(xí)筆記之觀察者模式

    Java學(xué)習(xí)筆記之觀察者模式

    這篇文章主要為大家詳細(xì)介紹了Java學(xué)習(xí)筆記之觀察者模式的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • SpringCloud注冊中心之consul詳細(xì)講解使用方法

    SpringCloud注冊中心之consul詳細(xì)講解使用方法

    Consul是一款由HashiCorp公司開源的,用于服務(wù)治理的軟件,Spring Cloud Consul對其進(jìn)行了封裝,這篇文章主要介紹了springcloud組件consul服務(wù)治理,需要的朋友可以參考下
    2022-11-11
  • Java如何對方法進(jìn)行調(diào)用詳解

    Java如何對方法進(jìn)行調(diào)用詳解

    今天給大家整理了Java如何對方法進(jìn)行調(diào)用,文中有非常詳細(xì)的介紹及代碼示例,對正在學(xué)習(xí)java的小伙伴們很有幫助,需要的朋友可以參考下
    2021-06-06
  • 詳談異步log4j2中的location信息打印問題

    詳談異步log4j2中的location信息打印問題

    這篇文章主要介紹了詳談異步log4j2中的location信息打印問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • RocketMQ源碼解析topic創(chuàng)建機(jī)制詳解

    RocketMQ源碼解析topic創(chuàng)建機(jī)制詳解

    這篇文章主要為大家介紹了RocketMQ源碼解析topic創(chuàng)建機(jī)制詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問題

    解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問題

    這篇文章主要介紹了mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò),解決辦法也很簡單只需要在application.properties配置文中的數(shù)據(jù)源url后面添加一個(gè)參數(shù),需要的朋友可以參考下
    2022-02-02
  • Java sm3加密算法的實(shí)現(xiàn)

    Java sm3加密算法的實(shí)現(xiàn)

    這篇文章主要介紹了Java sm3加密算法的實(shí)現(xiàn),幫助大家更好的利用Java進(jìn)行加密,感興趣的朋友可以了解下
    2020-10-10
  • 詳解如何使用IntelliJ IDEA新建一個(gè)Servlet項(xiàng)目

    詳解如何使用IntelliJ IDEA新建一個(gè)Servlet項(xiàng)目

    這篇文章主要介紹了詳解如何使用IntelliJ IDEA新建一個(gè)Servlet項(xiàng)目,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • spring源碼學(xué)習(xí)之bean的初始化以及循環(huán)引用

    spring源碼學(xué)習(xí)之bean的初始化以及循環(huán)引用

    這篇文章主要給大家介紹了關(guān)于spring源碼學(xué)習(xí)之bean的初始化以及循環(huán)引用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10

最新評論