JDBC是Sun公司制定的一個能夠用Java語言連線資料庫的技術。
一、JDBC基礎知識
JDBC(Java Data Base Connectivity,java資料庫連線)是一種用於執行SQL語句的Java API,能夠為多種關聯式資料庫提供統一訪問,它由一組用Java語言編寫的類和介面組成。JDBC為資料庫開發者提供了一個標準的API,據此能夠構建更高階的工具和介面,使資料庫開發者能夠用純 Java API 編寫資料庫應用程式,而且可跨平臺執行,而且不受資料庫供應商的限制。
1、跨平臺執行:這是繼承了Java語言的“一次編譯,到處執行”的特點;
2、不受資料庫供應商的限制:巧妙在於JDBC設有兩種介面,一個是面向應用程式層,其作用是使得開發者通過SQL呼叫資料庫和處理結果,而不須要考慮資料庫的提供商;還有一個是驅動程式層,處理與詳細驅動程式的互動,JDBC驅動程式能夠利用JDBC API建立Java程式和資料來源之間的橋樑。應用程式僅僅須要編寫一次,便能夠移到各種驅動程式上執行。Sun提供了一個驅動管理器,資料庫供應商——如MySQL、Oracle,提供的驅動程式滿足驅動管理器的要求就能夠被識別,就能夠正常工作。所以JDBC不受資料庫供應商的限制。
JDBC API能夠作為連線Java應用程式與各種關聯式資料庫的紐帶,在帶來方便的同一時候也有負面影響,下面是JDBC的優、缺點。長處例如以下:
- 操作便捷:JDBC使得開發者不須要再使用複雜的驅動器呼叫命令和函式;
- 可移植性強:JDBC支援不同的關聯式資料庫,所以能夠使同一個應用程式支援多個資料庫的訪問,僅僅要載入對應的驅動程式就可以;
- 通用性好:JDBC-ODBC橋接驅動器將JDBC函式換成ODBC;
- 物件導向:能夠將經常使用的JDBC資料庫連線封裝成一個類,在使用的時候直接呼叫就可以。
缺點例如以下:
- 訪問資料記錄的速度受到一定程度的影響;
- 更改資料來源困難:JDBC可支援多種資料庫,各種資料庫之間的操作必有不同,這就給更改資料來源帶來了非常大的麻煩
二、JDBC連線資料庫的流程及其原理
1、在開發環境中載入指定資料庫的驅動程式。比如,接下來的實驗中,使用的資料庫是MySQL,所以須要去下載MySQL支援JDBC的驅動程式(最新的是:mysql-connector-java-5.1.18-bin.jar);而開發環境是MyEclipse,將下載得到的驅動程式載入進開發環境中(詳細演示樣例的時候會解說怎樣載入)。
2、在Java程式中載入驅動程式。在Java程式中,能夠通過 “Class.forName(“指定資料庫的驅動程式”)” 方式來載入加入�到開發環境中的驅動程式,比如載入MySQL的資料驅動程式的程式碼為: Class.forName(“com.mysql.jdbc.Driver”)
3、建立資料連線物件:通過DriverManager類建立資料庫連線物件Connection。DriverManager類作用於Java程式和JDBC驅動程式之間,用於檢查所載入的驅動程式能否夠建立連線,然後通過它的getConnection方法,依據資料庫的URL、username和password,建立一個JDBC Connection 物件。如:Connection connection = DriverManager.geiConnection(“連線資料庫的URL", "username", "password”)。當中,URL=協議名+IP地址(域名)+port+資料庫名稱;username和password是指登入資料庫時所使用的username和password。詳細演示樣例建立MySQL的資料庫連線程式碼例如以下:
Connection connectMySQL = DriverManager.geiConnection(“jdbc:mysql://localhost:3306/myuser","root" ,"root" );
4、建立Statement物件:Statement 類的主要是用於執行靜態 SQL 語句並返回它所生成結果的物件。通過Connection 物件的 createStatement()方法能夠建立一個Statement物件。比如:Statement statament = connection.createStatement(); 詳細演示樣例建立Statement物件程式碼例如以下:
Statement statamentMySQL =connectMySQL.createStatement();
5、呼叫Statement物件的相關方法執行相相應的 SQL 語句:通過execuUpdate()方法用來資料的更新,包含插入和刪除等操作,比如向staff表中插入一條資料的程式碼:
statement.excuteUpdate( "INSERT INTO staff(name, age, sex,address, depart, worklen,wage)" + " VALUES ('Tom1', 321, 'M', 'china','Personnel','3','3000' ) ") ;
通過呼叫Statement物件的executeQuery()方法進行資料的查詢,而查詢結果會得到 ResulSet物件,ResulSet表示執行查詢資料庫後返回的資料的集合,ResulSet物件具有能夠指向當前資料行的指標。通過該物件的next()方法,使得指標指向下一行,然後將資料以列號或者欄位名取出。假設當next()方法返回null,則表示下一行中沒有資料存在。使用演示樣例程式碼例如以下:
ResultSet resultSel = statement.executeQuery( "select * from staff" );
6、關閉資料庫連線:使用完資料庫或者不須要訪問資料庫時,通過Connection的close() 方法及時關閉資料連線。
三、JDBC應用演示樣例實驗
實驗內容:使用phpMyAdmin在MySQL中建立資料庫(myuser),並加入�實驗所需的資料(新建staff表,加入�一些記錄);編寫Java程式,利用JDBC連線在MySQL中建立好的資料庫(myuser),對staff表格進行插入、更新、刪除和查詢等操作。
實驗環境及開發工具:Win7作業系統;jdk1.6.0_26;XAMPP1.7.7(MySQL 5.1, phpMyAdmin);MyEclipse 8.5
實驗環境的搭建:可參考我的部落格
- Java環境搭配:http://blog.csdn.net/cxwen78/article/details/6400798;
- windows系統XAMPP安裝配置使用:http://blog.csdn.net/cxwen78/article/details/6847927
實驗過程及步驟:
1、下載MySQL支援JDBC的驅動程式:假設已經有了,可跳過這一步。前往MySQL官網(http://www.mysql.com/products/connector/ )下載驅動程式,,MySQL針對不同的平臺提供了不同的聯結器,我們須要的是DBC Driver for MySQL (Connector/J),例如以下圖所看到的,點選 Download 跟著站點的引導進行下載。開啟下載得到的壓縮包(mysql-connector-java-5.1.18.zip),將當中的Java包(mysql-connector-java-5.1.18-bin.jar),拷貝到MySQL資料夾下(僅是為了方便才放到這裡),以備載入驅動程式時使用。
2、建立資料庫:使用phpMyAdmin,登入MySQL,建立資料庫myuser,並在當中插入一個名為staff的表格。並加入�一些資料,操作步驟如圖,登入進去MySQL資料庫後:
1)建立資料庫,名稱為myuser,編碼為utf8_general_ci(支援中文);
2)新建表格,名稱為staff,表格有8個欄位;
3)8個欄位的設定,包含名稱、型別、值的長度、初始值、編碼等等(點選檢視大圖);
4)加入�成功後,檢視的staff表格情況:
5)往表格中插入一些實驗所需資料,須要插入兩條,一個是員工lucy的,還有lili的:
3、在MyEclips中建立專案並在專案中加入�MySQL驅動程式:建立的專案型別能夠是Java專案或者是Java Web專案都能夠。這裡建立的是Web專案,專案名稱能夠隨便取,我命名為“JavaWebChp07”。建立成功後將步驟1裡下載得到的MySQL驅動程式包(mysql-connector-java-5.1.18-bin.jar)加入�到project的Build path中,加入�過程如圖所看到的:
4、編寫JDBC連線MySQL資料庫的例項詳細程式碼,JDBC_Test.java:
詳細程式碼:
<pre name="code" class="java">package chp07;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBC_Test {
// 建立靜態全域性變數
static Connection conn;
static Statement st;
public static void main(String[] args) {
insert(); //插入加入�記錄
update(); //更新記錄資料
delete(); //刪除記錄
query(); //查詢記錄並顯示
}
/* 插入資料記錄,並輸出插入的資料記錄數*/
public static void insert() {
conn = getConnection(); // 首先要獲取連線,即連線到資料庫
try {
String sql = "INSERT INTO staff(name, age, sex,address, depart, worklen,wage)"
+ " VALUES ('Tom1', 32, 'M', 'china','Personnel','3','3000')"; // 插入資料的sql語句
st = (Statement) conn.createStatement(); // 建立用於執行靜態sql語句的Statement物件
int count = st.executeUpdate(sql); // 執行插入操作的sql語句,並返回插入資料的個數
System.out.println("向staff表中插入 " + count + " 條資料"); //輸出插入操作的處理結果
conn.close(); //關閉資料庫連線
} catch (SQLException e) {
System.out.println("插入資料失敗" + e.getMessage());
}
}
/* 更新符合要求的記錄,並返回更新的記錄數目*/
public static void update() {
conn = getConnection(); //相同先要獲取連線,即連線到資料庫
try {
String sql = "update staff set wage='2200' where name = 'lucy'";// 更新資料的sql語句
st = (Statement) conn.createStatement(); //建立用於執行靜態sql語句的Statement物件,st屬區域性變數
int count = st.executeUpdate(sql);// 執行更新操作的sql語句,返回更新資料的個數
System.out.println("staff表中更新 " + count + " 條資料"); //輸出更新操作的處理結果
conn.close(); //關閉資料庫連線
} catch (SQLException e) {
System.out.println("更新資料失敗");
}
}
/* 查詢資料庫,輸出符合要求的記錄的情況*/
public static void query() {
conn = getConnection(); //相同先要獲取連線,即連線到資料庫
try {
String sql = "select * from staff"; // 查詢資料的sql語句
st = (Statement) conn.createStatement(); //建立用於執行靜態sql語句的Statement物件,st屬區域性變數
ResultSet rs = st.executeQuery(sql); //執行sql查詢語句,返回查詢資料的結果集
System.out.println("最後的查詢結果為:");
while (rs.next()) { // 推斷是否還有下一個資料
// 依據欄位名獲取對應的值
String name = rs.getString("name");
int age = rs.getInt("age");
String sex = rs.getString("sex");
String address = rs.getString("address");
String depart = rs.getString("depart");
String worklen = rs.getString("worklen");
String wage = rs.getString("wage");
//輸出查到的記錄的各個欄位的值
System.out.println(name + " " + age + " " + sex + " " + address
+ " " + depart + " " + worklen + " " + wage);
}
conn.close(); //關閉資料庫連線
} catch (SQLException e) {
System.out.println("查詢資料失敗");
}
}
/* 刪除符合要求的記錄,輸出情況*/
public static void delete() {
conn = getConnection(); //相同先要獲取連線,即連線到資料庫
try {
String sql = "delete from staff where name = 'lili'";// 刪除資料的sql語句
st = (Statement) conn.createStatement(); //建立用於執行靜態sql語句的Statement物件,st屬區域性變數
int count = st.executeUpdate(sql);// 執行sql刪除語句,返回刪除資料的數量
System.out.println("staff表中刪除 " + count + " 條資料\n"); //輸出刪除操作的處理結果
conn.close(); //關閉資料庫連線
} catch (SQLException e) {
System.out.println("刪除資料失敗");
}
}
/* 獲取資料庫連線的函式*/
public static Connection getConnection() {
Connection con = null; //建立用於連線資料庫的Connection物件
try {
Class.forName("com.mysql.jdbc.Driver");// 載入Mysql資料驅動
con = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/myuser", "root", "root");// 建立資料連線
} catch (Exception e) {
System.out.println("資料庫連線失敗" + e.getMessage());
}
return con; //返回所建立的資料庫連線
}
}
專案部署到server,然後執行結果:
http://www.5678520.com/kaiwangdian/130.html
http://www.5678520.com/kaiwangdian/129.html
http://www.5678520.com/kaiwangdian/128.html
http://www.5678520.com/kaiwangdian/127.html
http://www.5678520.com/kaiwangdian/126.html
http://www.lianzhiwei.com/News/389/20122116.html
http://www.lianzhiwei.com/News/389/20122115.html
http://www.lianzhiwei.com/News/389/20122114.html
http://www.lianzhiwei.com/News/389/20122113.html
http://www.lianzhiwei.com/News/389/20122112.html