亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁/技術文章
文章詳情頁

JDBC核心技術詳解

瀏覽:69日期:2022-08-13 10:10:18
一、JDBC概述

1、數據的持久化

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

持久化的主要應用是將內存中的數據存儲在關系型數據庫中,當然也可以存儲在磁盤文件、XML數據文件中。

JDBC核心技術詳解

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

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

3、JDBC基礎

JDBC核心技術詳解

連接數據庫:

JDBC核心技術詳解JDBC核心技術詳解

4、JDBC體系結構

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

Ø 面向應用的API:Java API,抽象接口,供應用程序開發人員使用(連接數據庫,執行SQL語句,獲得結果)。

Ø 面向數據庫的API:Java Driver API,供開發商開發數據庫驅動程序用。

JDBC核心技術詳解

5、JDBC API

JDBC API 是一系列的接口,它使得應用程序能夠進行數據庫聯接,執行SQL語句,并且得到返回結果。

JDBC核心技術詳解

6、JDBC程序訪問數據庫步驟

JDBC核心技術詳解JDBC核心技術詳解

二、獲取數據庫連接

1、Driver 接口

java.sql.Driver 接口是所有 JDBC 驅動程序需要實現的接口。這個接口是提供給數據庫廠商使用的,不同數據庫廠商提供不同的實現

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

2、加載與注冊 JDBC 驅動

JDBC核心技術詳解

3、建立連接(Connection)

JDBC核心技術詳解

4、幾種常用數據庫的JDBC URL

JDBC核心技術詳解

連接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實現類對象;使用反射 Class clazz= Class.forName('com.mysql.jdbc.Driver'); Driver driver=(Driver) clazz.newInstance(); //提供要連接的數據庫 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'; //注冊驅動 DriverManager.registerDriver(driver);//獲取連接 Connection connection= (Connection) DriverManager.getConnection(url,user,password); System.out.println(connection); }@Test //方式四,可以只是加載驅動,不用是示的注冊驅動過了。 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();// // //注冊驅動// DriverManager.registerDriver(driver);////獲取連接 Connection connection= (Connection) DriverManager.getConnection(url,user,password); System.out.println(connection); }@Test //方式五,(final版):將數據庫連接需要的4個基本信息聲明在配置文件中,通過讀取配置文件的方式,獲取連接 //實現了數據和代碼的分離(解耦) 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操作數據表的弊端 a、需要拼寫SQL語句

JDBC核心技術詳解

6、Statement操作會導致SQL注入攻擊

JDBC核心技術詳解

數據庫連接被用于向數據庫服務器發送命令和SQL語句,并接受數據庫服務器返回的結果。其實一個數據庫連接就是一個Socket連接。

在java.sql包中有3個接口分別定義了對數據庫的調用的不同方式:

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

-JDBC核心技術詳解

JDBC核心技術詳解JDBC核心技術詳解

到此這篇關于JDBC核心技術詳解的文章就介紹到這了,更多相關JDBC核心技術內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JDBC
相關文章:
主站蜘蛛池模板: 亚洲精品美女国产一区 | 免费视频a | 中文字幕亚洲国产 | 黄色一级视频在线播放 | 亚洲成在人线影视天堂网 | 国产一级二级三级视频 | 欧美亚洲日本一区二区三区浪人 | 国产成人综合怡春院精品 | 草草视频在线 | 久热99这里只有精品视频6 | 日本96在线精品视频免费观看 | 伊人激情网 | 欧美一区二区三区不卡免费 | 草草视频在线 | 一级片黄色a | 在线播放高清国语自产拍免费 | 国产永久免费高清动作片www | 中文字幕一区精品欧美 | 久久亚洲黄色 | 尤物视频免费观看 | 777久久 | 国产高清精品入口麻豆 | 亚洲欧美激情综合首页 | 国产精品免费观看视频 | 国产 日韩 一区 | 国产日韩一区 | 三级黄色在线视频中文 | 免费视频精品一区二区 | 亚洲欧美日韩精品久久亚洲区色播 | 成人片在线播放 | 日韩一级生活片 | 亚洲精品色一区二区三区 | 国产免费小视频 | 野外三级国产在线观看 | 精品三级国产精品经典三 | 在线看欧美日韩中文字幕 | 欧美1区二区三区公司 | 日韩一区二三区无 | 一区二区手机视频 | 久久日本精品国产精品白 | 国内精品自在欧美一区 |