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

JDBC核心技術(shù)詳解

 更新時間:2021年05月08日 14:44:05   作者:北街風(fēng)  
這篇文章主要介紹了JDBC核心技術(shù)詳解,文中有非常詳細的代碼示例,對正在學(xué)習(xí)JDBC的小伙伴們有很好的幫助,需要的朋友可以參考下

一、JDBC概述

1、數(shù)據(jù)的持久化

持久化(persistence):把數(shù)據(jù)保存到可掉電式存儲設(shè)備中以供之后使用。大多數(shù)情況下,特別是企業(yè)級應(yīng)用,數(shù)據(jù)持久化意味著將內(nèi)存中的數(shù)據(jù)保存到硬盤上加以"固化”,而持久化的實現(xiàn)過程大多通過各種關(guān)系數(shù)據(jù)庫來完成。

持久化的主要應(yīng)用是將內(nèi)存中的數(shù)據(jù)存儲在關(guān)系型數(shù)據(jù)庫中,當(dāng)然也可以存儲在磁盤文件、XML數(shù)據(jù)文件中。

在這里插入圖片描述

2、Java 中的數(shù)據(jù)存儲技術(shù) 在Java中,數(shù)據(jù)庫存取技術(shù)可分為如下幾類:

ØJDBC直接訪問數(shù)據(jù)庫
ØJDO技術(shù)
Ø第三方O/R工具,如Hibernate, mybatis 等JDBC是java訪問數(shù)據(jù)庫的基石,JDO, Hibernate等只是更好
的封裝了JDBC

3、JDBC基礎(chǔ)

在這里插入圖片描述

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

在這里插入圖片描述
在這里插入圖片描述

4、JDBC體系結(jié)構(gòu)

JDBC接口(API)包括兩個層次:

Ø 面向應(yīng)用的API:Java API,抽象接口,供應(yīng)用程序開發(fā)人員使用(連接數(shù)據(jù)庫,執(zhí)行SQL語句,獲得結(jié)果)。

Ø 面向數(shù)據(jù)庫的API:Java Driver API,供開發(fā)商開發(fā)數(shù)據(jù)庫驅(qū)動程序用。

在這里插入圖片描述

5、JDBC API

JDBC API 是一系列的接口,它使得應(yīng)用程序能夠進行數(shù)據(jù)庫聯(lián)接,執(zhí)行SQL語句,并且得到返回結(jié)果。

在這里插入圖片描述

6、JDBC程序訪問數(shù)據(jù)庫步驟

在這里插入圖片描述
在這里插入圖片描述

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

1、Driver 接口

java.sql.Driver 接口是所有 JDBC 驅(qū)動程序需要實現(xiàn)的接口。這個接口是提
供給數(shù)據(jù)庫廠商使用的,不同數(shù)據(jù)庫廠商提供不同的實現(xiàn)

在程序中不需要直接去訪問實現(xiàn)了 Driver 接口的類,而是由驅(qū)動程序管理
器類(java.sql.DriverManager)去調(diào)用這些Driver實現(xiàn)
ØOracle的驅(qū)動:oracle.jdbc.driver.OracleDriver
ØmySql的驅(qū)動: com.mysql.jdbc.Driver

2、加載與注冊 JDBC 驅(qū)動

在這里插入圖片描述

3、建立連接(Connection)

在這里插入圖片描述

4、幾種常用數(shù)據(jù)庫的JDBC URL

在這里插入圖片描述

連接mysql代碼實例:

import java.io.InputStream;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;

import org.junit.Test;

import com.mysql.jdbc.Connection;
import com.mysql.jdbc.Driver;

public class testconnction01 {
 
	
    /**
     * @throws SQLException
     */
    @Test
    //方式一
	public void testConnection011() throws SQLException {
		Driver driver = new com.mysql.jdbc.Driver();
		String url = "jdbc:mysql://localhost:3306/test";
		Properties info = new Properties();
		info.setProperty("user", "root");
		info.setProperty("password", "root");
		Connection collection = (Connection) driver.connect(url, info);
		System.out.println(collection);
	}
    
    @Test
    //方式二,對方式一的迭代,使得程序具有更好的可移植性
   	public void testConnection02() throws Exception {
   		//獲取Driver實現(xiàn)類對象;使用反射
   		Class clazz= Class.forName("com.mysql.jdbc.Driver");
   		Driver driver=(Driver) clazz.newInstance();
   		//提供要連接的數(shù)據(jù)庫
   		String url = "jdbc:mysql://localhost:3306/test";
   		//提供連接需要的用戶名和密碼
   		Properties info = new Properties();
   		info.setProperty("user", "root");
   		info.setProperty("password", "root");
   		//獲取連接
   		Connection collection = (Connection) driver.connect(url, info);
   		System.out.println(collection);
   	}
    
    @Test
    //方式三,使用DriverManager替換Driver
   	public void testConnection03() throws Exception {
    	Class clazz= Class.forName("com.mysql.jdbc.Driver");
   		Driver driver=(Driver) clazz.newInstance();
   		
   		//提供另外三個連接的基本信息;
   		String url ="jdbc:mysql://localhost:3306/test";
   		String user ="root";
   		String password ="root";
   		
    	//注冊驅(qū)動
    	DriverManager.registerDriver(driver);
    	
    	//獲取連接
    	Connection connection= (Connection) DriverManager.getConnection(url,user,password);
   		System.out.println(connection);
   	}
    
    @Test
    //方式四,可以只是加載驅(qū)動,不用是示的注冊驅(qū)動過了。
   	public void testConnection04() throws Exception {
   
   		//提供另外三個連接的基本信息;
   		String url ="jdbc:mysql://localhost:3306/test";
   		String user ="root";
   		String password ="root";
   		
   		Class.forName("com.mysql.jdbc.Driver");
   		
//   		Class clazz= Class.forName("com.mysql.jdbc.Driver");
//   		Driver driver=(Driver) clazz.newInstance();
//   		
//    	//注冊驅(qū)動
//    	DriverManager.registerDriver(driver);
//    	
    	//獲取連接
    	Connection connection= (Connection) DriverManager.getConnection(url,user,password);
   		System.out.println(connection);
   	}
    
    @Test
    //方式五,(final版):將數(shù)據(jù)庫連接需要的4個基本信息聲明在配置文件中,通過讀取配置文件的方式,獲取連接
    //實現(xiàn)了數(shù)據(jù)和代碼的分離(解耦)
   	public void testConnection05() throws Exception {
   
   	//讀取配置文件的4個基本信息
    InputStream is = testconnction01.class.getClassLoader().getResourceAsStream("jdbc.properties");
    
      Properties p =new Properties();
      p.load(is);
      
      String user = p.getProperty("user");
      String password = p.getProperty("password");
      String url = p.getProperty("url");
      String driverClass =p.getProperty("driverClass");
      
      Class.forName(driverClass);
      
        //獲取連接
  	    Connection connection= (Connection) DriverManager.getConnection(url,user,password);
 		System.out.println(connection);
   	}
}

5、使用Statement操作數(shù)據(jù)表的弊端 a、需要拼寫SQL語句

在這里插入圖片描述

6、Statement操作會導(dǎo)致SQL注入攻擊

在這里插入圖片描述

數(shù)據(jù)庫連接被用于向數(shù)據(jù)庫服務(wù)器發(fā)送命令和SQL語句,并接受數(shù)據(jù)庫服務(wù)器返回的結(jié)果。其實一個數(shù)據(jù)庫連接就是一個Socket連接。

在java.sql包中有3個接口分別定義了對數(shù)據(jù)庫的調(diào)用的不同方式:

Statement :用于執(zhí)行靜態(tài)SQL語句并返回它所生成結(jié)果的對象。PrepatedIatement : SQL語句被預(yù)編譯并存儲在此對象中,可以使用此對象多次高效地執(zhí)行該語句。CallableStatement :用于執(zhí)行SQL存儲過程

-在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述

到此這篇關(guān)于JDBC核心技術(shù)詳解的文章就介紹到這了,更多相關(guān)JDBC核心技術(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springboot+mybatis+枚舉處理器的實現(xiàn)

    springboot+mybatis+枚舉處理器的實現(xiàn)

    在Spring?boot項目開發(fā)中經(jīng)常遇到需要使用枚舉的場景,本文就介紹了springboot+mybatis+枚舉處理器的實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • java回調(diào)機制實例詳解

    java回調(diào)機制實例詳解

    這篇文章主要介紹了java回調(diào)機制實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • SpringBoot集成IJPay實現(xiàn)微信v3支付的示例代碼

    SpringBoot集成IJPay實現(xiàn)微信v3支付的示例代碼

    本文主要介紹了SpringBoot集成IJPay實現(xiàn)微信v3支付的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • java打jar包與找不到依賴包的問題

    java打jar包與找不到依賴包的問題

    這篇文章主要介紹了java打jar包與找不到依賴包的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • SpringMVC表單提交參數(shù)400錯誤解決方案

    SpringMVC表單提交參數(shù)400錯誤解決方案

    這篇文章主要介紹了SpringMVC表單提交參數(shù)400錯誤解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-10-10
  • IDEA利用jclasslib 修改class文件的實現(xiàn)

    IDEA利用jclasslib 修改class文件的實現(xiàn)

    這篇文章主要介紹了IDEA利用jclasslib 修改class文件的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Intellij IDEA 配置Subversion插件實現(xiàn)步驟詳解

    Intellij IDEA 配置Subversion插件實現(xiàn)步驟詳解

    這篇文章主要介紹了Intellij IDEA 配置Subversion插件實現(xiàn)步驟詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • java文件刪除不了File類的delete方法刪不掉文件的原因以及分析

    java文件刪除不了File類的delete方法刪不掉文件的原因以及分析

    這篇文章主要介紹了java文件刪除不了File類的delete方法刪不掉文件的原因以及分析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Java中MessageFormat的使用詳解

    Java中MessageFormat的使用詳解

    本文主要介紹了Java中MessageFormat的使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • 使用Spring Security集成手機驗證碼登錄功能實現(xiàn)

    使用Spring Security集成手機驗證碼登錄功能實現(xiàn)

    本文詳細介紹了如何利用SpringSecurity來實現(xiàn)手機驗證碼的注冊和登錄功能,在登錄過程中,同樣需通過驗證碼進行驗證,文章還提供了相關(guān)的代碼實現(xiàn)
    2024-10-10

最新評論