JDBC使用小結(jié)
1.首先說明什么是JDBC
在第一眼看到這個名詞之前,我覺得有必要知道它的英文全稱是什么,Java Database Connectivity,從英文字面上理解就直譯為
可連通的Java數(shù)據(jù)庫,說白了也就是想提供一套中間環(huán)節(jié),去連接Java代碼與數(shù)據(jù)庫,使之可以直接通過操作Java代碼就可以控制數(shù)據(jù)庫。
2.JDBC的實質(zhì)
它是Java訪問數(shù)據(jù)庫的解決方案,希望能過用同樣的方式訪問不同的數(shù)據(jù)庫,以達到實現(xiàn)與具體數(shù)據(jù)庫無關(guān)的Java操作界面。
JDBC實質(zhì)上就是就是一套標(biāo)準(zhǔn)化的接口,不同的數(shù)據(jù)庫廠商根據(jù)自己的數(shù)據(jù)庫特點去實現(xiàn)這套接口,實現(xiàn)的具體方法無需我們?nèi)リP(guān)心。
JDBC中數(shù)據(jù)庫廠商實現(xiàn)的主要接口如下:
DriverManager :驅(qū)動管理
Connection、
DatabaseMetaData :連接接口
Statement、
PreparedStatement
CallableStatement: 語句對象接口
ResultSet、
ResultSetMetaData: 結(jié)果集接口
3.JDBC的工作原理
程序員調(diào)用的是底層數(shù)據(jù)庫廠商實現(xiàn)的部分,
即:1)通過Connection 接口實現(xiàn)第一步的連接
2)通過Statement結(jié)果傳送sql語句
3)數(shù)據(jù)庫返回結(jié)果保存到ResultSet結(jié)果集合接口中
主要流程可歸納為:
1)加載驅(qū)動,創(chuàng)建連接
2)創(chuàng)建語句對象
3)執(zhí)行SQL語句
4)發(fā)回結(jié)果集
5)關(guān)閉連接
下面我以我學(xué)的oracle數(shù)據(jù)庫配合eclips為例逐步闡述一下如何實現(xiàn)JDBC
1)加載驅(qū)動
使用的方法為:Class.forName(“驅(qū)動”);
對于如何獲得到這個驅(qū)動,我所知道的方法是:展開JDBC的jar包,如我使用的是ojdbc6.jar,在里面找到oracle.jdbc.driver,在里面再找到OracleDriver然后鼠標(biāo)右鍵點qualitycopy,粘貼到引號之中即可,如:Class.forName("oracle.jdbc.driver.OracleDriver");
2)創(chuàng)建連接
使用的方法為: conn=DriverManager.getConnection(“jdbc:oracle:thin:@IP地址:1521:orcl","數(shù)據(jù)庫賬號","數(shù)據(jù)庫密碼”);
如:conn=DriverManager.getConnection("jdbc:oracle:thin:@172.16.3.8:1521:orcl","jsd1601","jsd1601");
3)創(chuàng)建語句對象
使用的方法為:Statement stmt=conn.createStatement();
需要注意的是,使用的是第二步上面創(chuàng)建出來的連接去調(diào)用方法
調(diào)用executeUpdate方法將sql語句傳入其中即可執(zhí)行所寫的sql語句,這里需要注意的是,executeUpdate方法能執(zhí)行的sql種類為insert,update,delete
如: Statement stmt=conn.createStatement();
String sql="insert into emp_jiawenzhe(empno,ename,sal,deptno) values(1000,'賈文哲',1500,10)";
int i=stmt.executeUpdate(sql);
這里面的返回值i就是受影響的行數(shù),我們可以根據(jù)這個受影響的行數(shù)來判斷是否操作成功
4)而對于返回的結(jié)果集主要是指進行select操作(這里暫不提)
5)最后關(guān)閉連接
如:conn.close();
列舉一整體代碼,包括注釋:
package jdbc_day01;
import java.sql.*;
/**
* 演示JDBC的操作步驟
* 1、加載驅(qū)動程序
* 2、創(chuàng)建連接
* 3、創(chuàng)建語句對象
* 4、發(fā)送SQL語句
* 5、如果發(fā)送的是select語句,處理結(jié)果集
* 6、關(guān)閉連接
* @author jiawenzhe
*
*/
public class JDBCDome01 {
public static void main(String[] args) throws SQLException {
//需求:創(chuàng)建一個員工,員工號,員工名,工資,部門號
//1、
Connection conn=null;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
System.out.println("驅(qū)動加載成功");
//2、
conn=
DriverManager.getConnection("jdbc:oracle:thin:@172.16.3.8:1521:orcl","jsd1601","jsd1601");
System.out.println(conn.getClass().getName());
//3、
//Statment 語句對象。發(fā)送并執(zhí)行SQL語句
/*
* int excuteUpdate(String sql);
* 發(fā)送insert,update,delete語句
* 返回值int表示影響數(shù)據(jù)庫表的行數(shù)
*/
Statement stmt=conn.createStatement();
String sql="insert into emp_jiawenzhe(empno,ename,sal,deptno) "
+ "values(1000,'王小二',1500,10)";
int i=stmt.executeUpdate(sql);
if(i>0){
System.out.println("保存成功!");
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
//1、記錄日志
//2、通知調(diào)用者
throw new RuntimeException("加載驅(qū)動錯誤",e);
}finally{
//關(guān)閉連接
if(conn!=null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
}
注:oracle數(shù)據(jù)庫可以使用的jar包:ojdbc14.jar/ojdbc6.jar(oracle12c用這個)
mysql數(shù)據(jù)庫可以使用的jar包:mysql-connector-java-5.0.4-bin.jar
加載驅(qū)動類:
Class.forName("com.mysql.jdbc.Driver");
1.封裝方法的引出
學(xué)了一段時間的Java給我感觸最深的就是,當(dāng)前寫某一系列的代碼的時候,如果出現(xiàn)了代碼的復(fù)用,肯定會選擇一種方法對代碼進行一定程度的封裝,從封裝一個方法到封裝一個類,之前有提到的使用JDBC進行數(shù)據(jù)庫的操作(增,刪,改,因為查詢涉及到對結(jié)果集的操作,將單獨聲明)分為四個過程:
1)加載驅(qū)動
2)創(chuàng)建連接
3)創(chuàng)建語句對象,發(fā)送SQL
4)關(guān)閉連接
也就是說我們在進行任何對數(shù)據(jù)庫操作的時候,都要進行上述步驟,這便出現(xiàn)了代碼的冗余,于是便提出了封裝這些共性的步驟到一個類中,使其能成為一種工具類,為我所用
2.三個版本的封裝
1.版本1
我在學(xué)習(xí)的時候是逐步對這些類進行一個漸進性的封裝,逐步完善的,因為如果直接提出終極版的封裝,對于初學(xué)者很難接受,下面我將闡述第一種也就是最簡單的封裝方法:
你在前面會發(fā)現(xiàn),無論你想如何操作數(shù)據(jù)庫,加載驅(qū)動都是必不可少的,而加載驅(qū)動里面主要就是聲明,驅(qū)動的名字,IP地址,端口號,數(shù)據(jù)庫賬戶名,密碼等等,而這些的實質(zhì)就是字符串所以我將這些字符串單獨定義出來,如下面所示:
private static String driverclass="oracle.jdbc.driver.OracleDriver"; private static String url="jdbc:oracle:thin:losthost:1521:orcl"; private static String user="system"; private static String password="123";
這樣在創(chuàng)建連接的時候我可以直接拿到變量的名字去代替很長的字符串,而加載驅(qū)動時地方法Class.forName,我們將它聲明在靜態(tài)塊中,因為加載數(shù)據(jù)的同時,加載了驅(qū)動
如下面所示:
static{
try {
Class.forName(driverclass);
} catch (ClassNotFoundException e) {
e.printStackTrace();
throw new RuntimeException("加載驅(qū)動錯誤",e);
}
}
對于創(chuàng)建連接,就是調(diào)用DriverManager的getConnection方法,并將對應(yīng)的用戶名,密碼放入其中,我們將這個方法直接放到我自己定義的方法中,然后直接調(diào)用我的方法便可以創(chuàng)建連接,需要注意的是,方法的返回值是Connection這個對象,很好理解,因為就是要拿到這個連接類型的對象,如下面所示:
public static Connection getConnection() throws SQLException{
Connection conn=
DriverManager.getConnection(url,user,password);
return conn;
}
然后是創(chuàng)建語句對象,發(fā)送SQL,當(dāng)然SQL是這里面唯一特殊的地方,因為SQL要做的事千差萬別,所以這個步驟就不用封裝了。
最后是關(guān)閉連接,就是調(diào)用了close()這個方法,如下面所示
public static void close(Connection conn){
if(conn!=null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException("關(guān)閉連接錯誤",e);
}
}
}
整體的第一版本的封裝如下面所示:
package jbbc_day01;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
/**
* 用來管理連接
* @author jiawenzhe
*
*/
public class DBUtil {
private static String driverclass="oracle.jdbc.driver.OracleDriver";
private static String url="jdbc:oracle:thin:losthost:1521:orcl";
private static String user="system";
private static String password="123";
//1、加載驅(qū)動
static{
try {
Class.forName(driverclass);
} catch (ClassNotFoundException e) {
e.printStackTrace();
throw new RuntimeException("加載驅(qū)動錯誤",e);
}
}
//2、創(chuàng)建連接
/*
* 如何定義一個能夠創(chuàng)建連接的方法
* 返回值類型:是否有運算結(jié)果,如果有,結(jié)果的類型即為返回值類型
* 參數(shù)列表:
* 方法功能中是否有不確定的數(shù)據(jù)參與運算,如果有,即為參數(shù)
*/
public static Connection getConnection() throws SQLException{
Connection conn=
DriverManager.getConnection(url,user,password);
return conn;
}
//3、關(guān)閉連接
public static void close(Connection conn){
if(conn!=null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException("關(guān)閉連接錯誤",e);
}
}
}
}
這樣一個封裝就好了,然后在進行SQL操作的時候直接調(diào)用這個封裝類就可以了,而你只需要寫的就是創(chuàng)建你的語句對象,發(fā)送你的SQL語句即可
2.版本2
其實版本2與版本一很類似,就是為了去彌補版本1的一個不足之處,就是,當(dāng)你更換數(shù)據(jù)庫的時候,不同數(shù)據(jù)庫的賬號密碼是不一樣的,這就要對賬號密碼和IP地址進行修改,我之前將這些以字符串的形式封裝在了工具類之中,那就意味著我們每次更換數(shù)據(jù)庫必須對工具類進行修改,這樣是很不妥當(dāng)?shù)?,于是提出了一種改進辦法就是將這些連接數(shù)據(jù)放到一個配置文件之中,工具類去讀取這個配置文件,我們在修改的時候直接去修改這個配置文件就可以了
在介紹這個版本之前,我前引出一個新類就是Properties,他就是一個能讀取文件,并以流的形式去讀取配置文件內(nèi)容然后返回給工具類的
首先我先把配置文件示例出來,其實不用解釋,一目了然,如下所示:
jdbc.driverclass=oracle.jdbc.driver.OracleDriver jdbc.url=jdbc:oracle:thin:localhost:orcl jdbc.user=system jdbc.password=123
前面是鍵,后面是值,前面的鍵值是我們自己定義的,就像定義變量名字一樣,后面的值就是我們數(shù)據(jù)庫的實際情況,這里我們需要特別注意的是,這個配置文件的后綴名一定要以.properties結(jié)尾,因為這樣Properties這個類才能讀取的到。
這部分的示例如下:
static{
try {
//加載屬性文件數(shù)據(jù)
Properties pop=new Properties();
pop.load(DBUtil2.class.getClassLoader().getResourceAsStream("db.properties"));
url=pop.getProperty("jdbc.url");
driverclass=pop.getProperty("jdbc.driverclass");
user=pop.getProperty("jdbc.user");
password=pop.getProperty("jdbc.password");
Class.forName(driverclass);
} catch (ClassNotFoundException e) {
e.printStackTrace();
throw new RuntimeException("加載驅(qū)動錯誤",e);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
load()這個方法就是去讀取也可以認(rèn)為是加載配置文件的,這個整整一句話記住就行,不用去深究其意義,而getProperty()就是通過鍵獲得到了對應(yīng)的值,很像鍵值對集合獲取值得形式
整體代碼如下:
package jbbc_day01;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
/**
* 用來管理連接
* 數(shù)據(jù)庫連接信息,保存在屬性文件中
* @author jiawenzhe
*
*/
public class DBUtil2 {
private static String driverclass;
private static String url;
private static String user;
private static String password;
//1、加載驅(qū)動
static{
try {
//加載屬性文件數(shù)據(jù)
Properties pop=new Properties();
pop.load(DBUtil2.class.getClassLoader().getResourceAsStream("db.properties"));
url=pop.getProperty("jdbc.url");
driverclass=pop.getProperty("jdbc.driverclass");
user=pop.getProperty("jdbc.user");
password=pop.getProperty("jdbc.password");
Class.forName(driverclass);
} catch (ClassNotFoundException e) {
e.printStackTrace();
throw new RuntimeException("加載驅(qū)動錯誤",e);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//2、創(chuàng)建連接
/*
* 如何定義一個能夠創(chuàng)建連接的方法
* 返回值類型:是否有運算結(jié)果,如果有,結(jié)果的類型即為返回值類型
* 參數(shù)列表:
* 方法功能中是否有不確定的數(shù)據(jù)參與運算,如果有,即為參數(shù)
*/
public static Connection getConnection() throws SQLException{
Connection conn=
DriverManager.getConnection(url,user,password);
return conn;
}
//3、關(guān)閉連接
public static void close(Connection conn){
if(conn!=null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException("關(guān)閉連接錯誤",e);
}
}
}
}
- JDBC 程序的常見錯誤及調(diào)試方法
- MyEclipse通過JDBC連接MySQL數(shù)據(jù)庫基本介紹
- 基于Java回顧之JDBC的使用詳解
- sqlserverdriver配置方法 jdbc連接sqlserver
- Java使用JDBC連接數(shù)據(jù)庫的實現(xiàn)方法
- JDBC基礎(chǔ)教程
- 在eclipse導(dǎo)入Java的jar包的方法JDBC(圖文說明)
- Java開發(fā)Oracle數(shù)據(jù)庫連接JDBC Thin Driver 的三種方法
- java實現(xiàn)jdbc查詢結(jié)果集result轉(zhuǎn)換成對應(yīng)list集合
- JSP使用JDBC連接MYSQL數(shù)據(jù)庫的方法
相關(guān)文章
Java中線程狀態(tài)+線程安全問題+synchronized的用法詳解
這篇文章主要介紹了Java中線程狀態(tài)+線程安全問題+synchronized的用法詳解,本文結(jié)合示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04
一篇文章帶你了解SpringMVC數(shù)據(jù)綁定
這篇文章主要給大家介紹了關(guān)于如何通過一篇文章弄懂Spring MVC的參數(shù)綁定,文中通過示例代碼以及圖文介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2021-08-08
Java?嵌入數(shù)據(jù)引擎從?SQLite?到?SPL詳解
這篇文章主要介紹了Java?嵌入數(shù)據(jù)引擎:從?SQLite?到?SPL,SQLite架構(gòu)簡單,其核心雖然是C語言開發(fā)的,但封裝得比較好,對外呈現(xiàn)為一個小巧的Jar包,能方便地集成在Java應(yīng)用中,本文給大家介紹的非常詳細,需要的朋友參考下2022-07-07

