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

Java 數(shù)據(jù)庫(kù)連接(JDBC)的相關(guān)總結(jié)

 更新時(shí)間:2021年03月24日 08:31:42   作者:拾階求上  
這篇文章主要介紹了Java 數(shù)據(jù)庫(kù)連接(JDBC)的相關(guān)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下

Java 數(shù)據(jù)庫(kù)連接(Java DataBase Connectivity,縮寫(xiě)JDBC)是官方(sun公司)定義的一套操作所有關(guān)系型數(shù)據(jù)庫(kù)的規(guī)則(即接口)。
各個(gè)數(shù)據(jù)庫(kù)廠商去實(shí)現(xiàn)這套接口,提供數(shù)據(jù)庫(kù)驅(qū)動(dòng)jar包。我們可以使用這套接口(JDBC)編程,真正執(zhí)行的代碼是驅(qū)動(dòng)jar包中的實(shí)現(xiàn)類。

一、JDBC API 概述

JDBC API主要位于JDK中的java.sql包中(之后擴(kuò)展的內(nèi)容位于javax.sql包中),主要包括(下面的接口,需驅(qū)動(dòng)程序提供者來(lái)具體實(shí)現(xiàn)):

  • DriverManager:負(fù)責(zé)加載各種不同驅(qū)動(dòng)程序(Driver),并根據(jù)不同的請(qǐng)求,向調(diào)用者返回相應(yīng)的數(shù)據(jù)庫(kù)連接(Connection)。
  • Driver:驅(qū)動(dòng)程序,會(huì)將自身加載到DriverManager中去,并處理相應(yīng)的請(qǐng)求,返回相應(yīng)的數(shù)據(jù)庫(kù)連接(Connection)。
  • Connection:與數(shù)據(jù)庫(kù)連接,負(fù)責(zé)與進(jìn)行數(shù)據(jù)庫(kù)間通訊,SQL執(zhí)行、事務(wù)處理都是在某個(gè)特定Connection環(huán)境中進(jìn)行的。
  • Statement:用以執(zhí)行SQL查詢和更新(針對(duì)靜態(tài)SQL語(yǔ)句和單次執(zhí)行)。
  • PreparedStatement:用以執(zhí)行包含動(dòng)態(tài)參數(shù)的SQL查詢和更新(在服務(wù)器端編譯,允許重復(fù)執(zhí)行以提高效率)。
  • CallableStatement:用以調(diào)用數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程。
  • SQLException:代表在數(shù)據(jù)庫(kù)連接的建立和關(guān)閉和SQL語(yǔ)句的執(zhí)行過(guò)程中發(fā)生了例外情況(即錯(cuò)誤)。

二、JDBC 和 數(shù)據(jù)庫(kù)建立連接的過(guò)程

2.1、裝載驅(qū)動(dòng)程序

Java 程序和數(shù)據(jù)庫(kù)建立連接,首先需要下載好對(duì)應(yīng)數(shù)據(jù)庫(kù)的驅(qū)動(dòng)程序包,并放置在程序的依賴庫(kù)中。
程序?qū)⒁蕾噹?kù)中的驅(qū)動(dòng)加載到程序中的方式非常簡(jiǎn)單,使用Class.forName()即可。

假如需要導(dǎo)入的驅(qū)動(dòng)包為 mysql-connector-java-5.1.37-bin.jar,則裝載驅(qū)動(dòng)的方式:
Class.forName("com.mysql.jdbc.Driver");
在驅(qū)動(dòng)程序的文檔中會(huì)告訴你應(yīng)該使用的類名。
在裝載驅(qū)動(dòng)的過(guò)程中,會(huì)執(zhí)行驅(qū)動(dòng)程序中的部分代碼(靜態(tài)代碼塊);實(shí)現(xiàn)驅(qū)動(dòng)與 DriverManager的綁定。

static {
 try {
  java.sql.DriverManager.registerDriver(new Driver());
 } catch (SQLException E) {
  throw new RuntimeException("Can't register driver!");
 }
 }

注意:mysql5之后的驅(qū)動(dòng)jar包可以省略注冊(cè)驅(qū)動(dòng)(forName)的步驟。Jar包中內(nèi)置包含處理了此過(guò)程。

2.2、獲取數(shù)據(jù)庫(kù)連接

下一步就是用適當(dāng)?shù)尿?qū)動(dòng)程序類與 DBMS 建立一個(gè)連接。
下列代碼是一般的做法:

Connection con = DriverManager.getConnection(url,user,password);

方法:static Connection getConnection(String url, String user, String password)
說(shuō)明:返回一個(gè)打開(kāi)的連接,你可以使用此連接創(chuàng)建 JDBC statements 并發(fā)送 SQL 語(yǔ)句到數(shù)據(jù)庫(kù)。
參數(shù):
    * url:指定連接的路徑;如:jdbc:mysql://localhost:3306/db3
    * user:用戶名
    * password:密碼

如果你裝載的驅(qū)動(dòng)程序識(shí)別了提供給 DriverManager.getConnection 的 JDBC URL ,那個(gè)驅(qū)動(dòng)程序?qū)⒏鶕?jù) JDBC URL 建立一個(gè)到指定 DBMS 的連接。
正如名稱所示,DriverManager 類在幕后為你管理建立連接的所有細(xì)節(jié)。
除非你是正在寫(xiě)驅(qū)動(dòng)程序,你可能無(wú)需使用此類的其它任何方法,一般程序員需要在此類中直接使用的唯一方法是 DriverManager.getConnection。

2.2.1、Connection:數(shù)據(jù)庫(kù)連接對(duì)象介紹

Connection 對(duì)象與數(shù)據(jù)庫(kù)連接;負(fù)責(zé)與進(jìn)行數(shù)據(jù)庫(kù)間通訊,SQL執(zhí)行以及事務(wù)處理都是在某個(gè)特定Connection環(huán)境中進(jìn)行的。

  1. 產(chǎn)生用以執(zhí)行SQL指令的 Statement、PreparedStatement 對(duì)象。
  2. 事務(wù)管理中:setAutoCommit(boolean autoCommit)開(kāi)啟事務(wù)、commit()提交事務(wù)、rollback()回滾事務(wù)。

2.3、創(chuàng)建 JDBC Statement 對(duì)象

Statement 是執(zhí)行SQL 的對(duì)象;其用于把 SQL 語(yǔ)句發(fā)送到 DBMS。不同的SQL語(yǔ)句使用不同的 Statement 對(duì)象的方法,發(fā)送到 DBMS中。

Statement stmt = con.createStatement();

2.4、執(zhí)行SQL 語(yǔ)句 (Statement對(duì)象方法使用)

不同的 SQL 語(yǔ)句需要使用不同的 Statement 對(duì)象方法。

  1. boolean execute(String sql):可以執(zhí)行任意的sql(了解 )。
  2. int executeUpdate(String sql):執(zhí)行DML(insert、update、delete)語(yǔ)句、DDL(create,alter、drop)語(yǔ)句。
  3. ResultSet executeQuery(String sql):執(zhí)行DQL(select)語(yǔ)句

其中 executeUpdate() 方法的返回值為影響的行數(shù);可以通過(guò)這個(gè)影響的行數(shù)判斷DML語(yǔ)句是否執(zhí)行成功 ;返回值>0的則執(zhí)行成功,反之,則失敗。

執(zhí)行DML語(yǔ)句

String sql = "insert into account values(null,'王五',3000)";
int count = stmt.executeUpdate(sql);//影響的行數(shù)

執(zhí)行DQL語(yǔ)句

ResultSet rs = stmt.executeQuery("SELECT user_name, age FROM student");
//如果有數(shù)據(jù),rs.next()返回true
while(rs.next()){
System.out.println(rs.getString("user_name")+" 年齡:"+rs.getInt("age"));
}

2.4.1、ResultSet 結(jié)果集對(duì)象,封裝查詢結(jié)果

java.sql.ResultSet 接口表示一個(gè)數(shù)據(jù)庫(kù)查詢的結(jié)果集;一個(gè)ResultSet對(duì)象具有一個(gè)游標(biāo)指向當(dāng)前行的結(jié)果集。
最初,光標(biāo)被置于第一行之前;調(diào)用 next() 方法將光標(biāo)移動(dòng)到下一行;當(dāng) ResultSet 對(duì)象沒(méi)有下一行時(shí),next() 方法返回 false。

一般使用方法:

while(rs.next()){
 //獲取數(shù)據(jù)
 int id = rs.getInt(1);
 String name = rs.getString("name");
 double balance = rs.getDouble(3);
 System.out.println(id + "---" + name + "---" + balance);
}

getXxx(參數(shù)):獲取數(shù)據(jù)
  * Xxx:代表數(shù)據(jù)類型如:int getInt(),String getString() ...
  * 參數(shù):
      1. int:代表列的編號(hào),從1開(kāi)始   如: getString(1)
      2. String:代表列名稱。 如: getDouble("balance")

2.5、釋放資源

SQL 語(yǔ)句執(zhí)行完成后,需要是否創(chuàng)建的資源對(duì)象。包括連接對(duì)象、Statement對(duì)象和ResultSet 對(duì)象等。

以上就是Java 數(shù)據(jù)庫(kù)連接(JDBC)的相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Java 數(shù)據(jù)庫(kù)連接(JDBC)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SpringBoot整合Mybatis注解開(kāi)發(fā)的實(shí)現(xiàn)代碼

    SpringBoot整合Mybatis注解開(kāi)發(fā)的實(shí)現(xiàn)代碼

    這篇文章主要介紹了SpringBoot整合Mybatis注解開(kāi)發(fā)的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Spring源碼解密之自定義標(biāo)簽與解析

    Spring源碼解密之自定義標(biāo)簽與解析

    這篇文章主要給大家介紹了關(guān)于Spring源碼解密之自定義標(biāo)簽與解析的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • Java之OutputStreamWriter流案例詳解

    Java之OutputStreamWriter流案例詳解

    這篇文章主要介紹了Java之OutputStreamWriter流案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • java使用bitmap實(shí)現(xiàn)可回收自增id的示例

    java使用bitmap實(shí)現(xiàn)可回收自增id的示例

    本文主要介紹了java使用bitmap實(shí)現(xiàn)可回收自增id的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-10-10
  • springboot利用AOP完成日志統(tǒng)計(jì)的詳細(xì)步驟

    springboot利用AOP完成日志統(tǒng)計(jì)的詳細(xì)步驟

    項(xiàng)目用到了過(guò)濾器,可能有的人會(huì)不理解,之所以用過(guò)濾器是因?yàn)橄胍谌罩居涗沺ost請(qǐng)求的json數(shù)據(jù)。本文重點(diǎn)給大家介紹springboot利用AOP完成日志統(tǒng)計(jì)的詳細(xì)步驟,感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • Java 注解的使用實(shí)例詳解

    Java 注解的使用實(shí)例詳解

    這篇文章主要介紹了Java 注解的使用實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • Kafka單節(jié)點(diǎn)偽分布式集群搭建實(shí)現(xiàn)過(guò)程詳解

    Kafka單節(jié)點(diǎn)偽分布式集群搭建實(shí)現(xiàn)過(guò)程詳解

    這篇文章主要介紹了Kafka單節(jié)點(diǎn)偽分布式集群搭建實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • SpringBoot的監(jiān)控及使用詳解

    SpringBoot的監(jiān)控及使用詳解

    這篇文章主要介紹了SpringBoot的監(jiān)控及使用詳解,Spring Boot提供了一系列的監(jiān)控功能,方便開(kāi)發(fā)人員對(duì)應(yīng)用程序進(jìn)行監(jiān)控和管理,本文將討論 Spring Boot中的監(jiān)控功能及其使用方法,需要的朋友可以參考下
    2023-07-07
  • Spring Boot使用JSR-380進(jìn)行校驗(yàn)的示例

    Spring Boot使用JSR-380進(jìn)行校驗(yàn)的示例

    這篇文章主要介紹了Spring Boot使用JSR-380進(jìn)行校驗(yàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • java保留小數(shù)的四種實(shí)現(xiàn)方法

    java保留小數(shù)的四種實(shí)現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了java保留小數(shù)的四種實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11

最新評(píng)論