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

java JDBC系列教程之JDBC類的簡析與JDBC的基礎(chǔ)操作

 更新時間:2020年07月27日 10:42:50   作者:一只胡說八道的猴子  
這篇文章主要介紹了java JDBC系列教程之JDBC類的簡析與JDBC的基礎(chǔ)操作,本文分步驟通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

什么是JDBC?

概念:JAVA Database Connectivity Javas數(shù)據(jù)庫連接,Java語言操作數(shù)據(jù)庫接口,然后由各個數(shù)據(jù)庫廠商去實現(xiàn)這個接口,提供數(shù)據(jù)庫驅(qū)動java包,我們可以使用這套接口,真正執(zhí)行的是jar驅(qū)動包中的實習(xí)類

使用一張圖讓大家更為直觀的理解:
coder就是寫這套接口的程序員

JDBC的使用步驟

1.導(dǎo)入驅(qū)動jar包
2.注冊驅(qū)動
3.獲取數(shù)據(jù)庫連接對象
4.定義sql執(zhí)行語句
5.獲取sql語句執(zhí)行對象
6.執(zhí)行sql語句返回結(jié)果
7.處理結(jié)果
8.釋放結(jié)果

代碼實現(xiàn)

package JDBC;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class Main {
  public static void main(String[] args) throws ClassNotFoundException, SQLException {
    //注冊驅(qū)動
    Class.forName("com.mysql.jdbc.Driver");
    //獲取數(shù)據(jù)庫連接對象
    Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3309/db2", "root", "1234");
    //定義sql語句
    String sql="update count set money=10000";
    //定義statement執(zhí)行語句
    Statement statement = connection.createStatement();
    //執(zhí)行sql語句
    int i = statement.executeUpdate(sql);
    System.out.println("共"+i+"行受到影響");
    //關(guān)閉資源
    statement.close();
    connection.close();
  }
}

類詳解

DriverManager:驅(qū)動管理對象

功能:
1.注冊驅(qū)動,告訴程序應(yīng)該使用哪個驅(qū)動的java包
static void registerDriver(Driver driver) :注冊與給定的驅(qū)動程序 DriverManager 。

寫代碼使用:

Class.forName("com.mysql.jdbc.Driver");

查看jar包下的源碼得:

package com.mysql.jdbc;
import java.sql.DriverManager;
import java.sql.SQLException;
public class Driver extends NonRegisteringDriver implements java.sql.Driver {
  public Driver() throws SQLException {
  }
  static {
    try {
    //注冊驅(qū)動
      DriverManager.registerDriver(new Driver());
    } catch (SQLException var1) {
      throw new RuntimeException("Can't register driver!");
    }
  }
}

我們可以發(fā)現(xiàn)在com.mysql.jdbc.Driver類中存在靜態(tài)代碼塊,內(nèi)部調(diào)用registerDriver(new Driver)注冊驅(qū)動
mysql5之后可以省略注冊驅(qū)動的步驟

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

方法:static connection getConnection(String sql,String password)
參數(shù):
* url:指定連接的路徑
* 語法:jdbc:mysql://ip地址(域名):端口號/數(shù)據(jù)庫名稱
* 例子:jdbc:mysql://localhost:3306/db3
* 細節(jié):如果連接的是本機mysql服務(wù)器,并且mysql服務(wù)默認端口是3306,則url可以簡寫 為:jdbc:mysql:///數(shù)據(jù)庫名稱
* user:用戶名
* password:密碼

**

Connection 數(shù)據(jù)庫連接對象**

1.功能
1.1 獲取sql語句的執(zhí)行對象
*Statement createStatement()
* PreparedStatement prepareStatement(String sql)

1.2 管理事務(wù)
開啟事務(wù):setAutoCommit(boolean autocommit),調(diào)用改方法,參數(shù)為false時開啟事務(wù)
提交事務(wù):commit();
回滾事務(wù):rollback()

1.3 statement:執(zhí)行sql語句的對象

執(zhí)行sql
1. boolean execute(String sql) :可以執(zhí)行任意的sql 了解
2. int executeUpdate(String sql) :執(zhí)行DML(insert、update、delete)語句、 DDL(create,alter、drop)語句
* 返回值:影響的行數(shù),可以通過這個影響的行數(shù)判斷DML語句是否執(zhí)行成功 返回值>0的則執(zhí)行成功,反之,則失敗。

**1.4ResultSet:結(jié)果集對象,封裝查詢結(jié)果**
 boolean next():游標(biāo)向下移動一行,判斷當(dāng)前行是不是最后一行,如果是則返回false,如果不是則返回true
 getXxx(參數(shù)):獲取數(shù)據(jù)
* Xxx:代表數(shù)據(jù)類型  如: int getInt() ,	String getString()
			* 參數(shù):
				1. int:代表列的編號,從1開始  如: getString(1)
				2. String:代表列名稱。 如: getDouble("balance")

使用步驟:

  • 游標(biāo)向下移動一行
  • 判斷是否有數(shù)據(jù)
  • 獲取數(shù)據(jù)

代碼演示

package JDBC;
import java.sql.*;
public class Main {
  public static void main(String[] args) throws ClassNotFoundException, SQLException {
    //注冊驅(qū)動
    Class.forName("com.mysql.jdbc.Driver");
    //獲取數(shù)據(jù)庫連接對象
    Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3309/db2", "root", "1234");
    //定義sql語句
    String sql="SELECT *FROM COUNT ";
    //定義statement執(zhí)行語句
    Statement statement = connection.createStatement();
    //執(zhí)行sql語句
    ResultSet resultSet = statement.executeQuery(sql);
    //循環(huán)輸出
    while(resultSet.next()){
      int anInt = resultSet.getInt(1);
      String string = resultSet.getString(2);
      int anInt2 = resultSet.getInt(3);
      System.out.println("ID:"+anInt);
      System.out.println("name:"+string);
      System.out.println("money:"+anInt2);
    }
    //關(guān)閉資源
    statement.close();
    connection.close();
  }
}

結(jié)果

到此這篇關(guān)于java JDBC系列教程之JDBC類的簡析與JDBC的基礎(chǔ)操作的文章就介紹到這了,更多相關(guān)java JDBC類與操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Jmeter實現(xiàn)Base64編碼的兩種方式

    Jmeter實現(xiàn)Base64編碼的兩種方式

    這篇文章主要介紹了Jmeter實現(xiàn)Base64編碼,大家都知道Jmeter實現(xiàn)Base64編碼有兩種方式,本文通過圖文并茂的形式把每種方法給大家介紹的非常詳細,需要的朋友可以參考下
    2022-01-01
  • SpringCloud 中使用 Ribbon的方法詳解

    SpringCloud 中使用 Ribbon的方法詳解

    本文重點給大家介紹SpringCloud 中使用 Ribbon的方法,本文通過實例文字相結(jié)合的形式給大家介紹的非常詳細,需要的朋友可以參考下
    2018-10-10
  • Java泛型中<?>和<T>的區(qū)別淺析

    Java泛型中<?>和<T>的區(qū)別淺析

    <T>和<?>的區(qū)別 <T>是參數(shù)類型,常常用于泛型類或泛型方法的定義,下面這篇文章主要給大家介紹了關(guān)于Java泛型中<?>和<T>區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • IntelliJ idea 如何生成動態(tài)的JSON字符串(步驟詳解)

    IntelliJ idea 如何生成動態(tài)的JSON字符串(步驟詳解)

    這篇文章主要介紹了IntelliJ idea 如何生成動態(tài)的JSON字符串,本文分步驟給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • 利用hadoop查詢兩兩之間有共同好友及他倆的共同好友都是誰

    利用hadoop查詢兩兩之間有共同好友及他倆的共同好友都是誰

    一想到要實現(xiàn)求共同好友的功能,很多人都會想到redis來實現(xiàn)。但是redis存儲和數(shù)據(jù)和計算時需要耗費較多的內(nèi)存資源。所以文本將介紹另一種方法,即利用Hadoop中的MapReduce來實現(xiàn),感興趣的可以了解一下
    2022-01-01
  • Java中的System.arraycopy()淺復(fù)制方法詳解

    Java中的System.arraycopy()淺復(fù)制方法詳解

    這篇文章主要介紹了Java中的System.arraycopy()淺復(fù)制方法詳解,Java數(shù)組的復(fù)制操作可以分為深度復(fù)制和淺度復(fù)制,簡單來說深度復(fù)制,可以將對象的值和對象的內(nèi)容復(fù)制;淺復(fù)制是指對對象引用的復(fù)制,需要的朋友可以參考下
    2023-11-11
  • 關(guān)于Java中的繼承和組合的一個錯誤使用的例子

    關(guān)于Java中的繼承和組合的一個錯誤使用的例子

    這篇文章主要介紹了關(guān)于Java中的繼承和組合的一個錯誤使用的例子,需要的朋友可以參考下
    2016-08-08
  • 基于strict-origin-when-cross-origin問題的解決

    基于strict-origin-when-cross-origin問題的解決

    這篇文章主要介紹了基于strict-origin-when-cross-origin問題的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 解決spring @ControllerAdvice處理異常無法正確匹配自定義異常

    解決spring @ControllerAdvice處理異常無法正確匹配自定義異常

    這篇文章主要介紹了解決spring @ControllerAdvice處理異常無法正確匹配自定義異常的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java精品項目瑞吉外賣之員工新增篇

    Java精品項目瑞吉外賣之員工新增篇

    這篇文章主要為大家詳細介紹了java精品項目-瑞吉外賣訂餐系統(tǒng),此項目過大,分為多章獨立講解,本篇內(nèi)容為新增員工功能的實現(xiàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05

最新評論