標籤:
JDBC簡介
1.SUN公司為了簡化,統一資料庫的操作,定義了一套Java操作資料庫的規範,稱之為JDBC
2.資料庫驅動
3.JDBC全稱為:JAVA DataBase Commectivity(java資料庫連接)
4.組成JDBC的兩個包(1 java.sql,2 javax.sql)。
5.DriverManager->Connection->Statement(PreparedStatement,CallableStatement)->ResultSet
6.JavaEE軟體分為了四個層次:
6.1、用戶端層:DHTML(HTML、CSS、JS)、Java Application
從第二層開始,位於伺服器端
6.2、web層(表現層):Servlet/JSP ---- 接收用戶端資料、將資料處理結構展示給用戶端、業務層調度 --- Struts
6.3、業務層(中介層):EJB ----- 根據系統商務程序 處理用戶端提交資料 --- Spring
6.4、資料層(持久層):JDBC介面 ------- 完成資料的持久化、從資料庫擷取資料 --- Hibernate/IBatis
企業裡 web層、業務層、資料層 統稱為三層結構 SSH:Struts+Spring+Hibernate
如何搭建一個JDBC程式
1.搭建環境
1.1 在(Mysql,SqlServer,Oracle..)等資料庫中建立一個資料庫和表
1.2 建立Java工程,並且針對不同的資料庫程式匯入資料庫驅動(maven)
2.JDBC如何?對資料庫的操作呢?
2.1 第一步:在程式中裝載驅動
2.1.1 DriverManager.registerDriver(new com.mysql.jdbc.Driver());
2.1.2 Class.forName("com.mysql.jdbc.Driver"); //開發中建議使用
2.2 第二步:獲得資料庫的串連
String url=""; //資料庫訪問路徑,唯一標示資料庫的位置
String user=""; //使用者名稱
String pass=""; //密碼
Connection conn=DriverManager.getConnection(url,user,pass);
2.3 第三步:建立用於向資料庫發送Sql的Statement對象,並且發送Sql
Statement stmt=conn.cteateStatement();
2.4 第四步: 通過Sql操作資料庫
String sql="";
ResultSet rs=stmt.executeQuery(sql); //得到資料結果集
2.5 第五步:釋放資源
關閉資源的順序一般為:先開的後關閉,後開的先關閉
ResultSet->Statement->Connection
3.讀取設定檔(*.properties)代碼如下:
ResourceBundle bundle=ResourceBundle.getBundle("*");
String driver=bundle.getString("driver");
程式詳解—DriverManager
1.Jdbc程式中的DriverManager用於載入驅動,並建立與資料庫的連結,這個API的常用方法:
DriverManager.registerDriver(new Driver())
DriverManager.getConnection(url, user, password),
備忘:在實際開發中並不推薦採用registerDriver方法註冊驅動。原因有二:
1.1 查看Driver的原始碼可以看到,如果採用此種方式,會導致驅動程式註冊兩次,也就是在記憶體中會有兩個Driver對象。
1.2 程式依賴mysql的api,脫離mysql的jar包,程式將無法編譯,將來程式切換底層資料庫將會非常麻煩。
2. 推薦載入驅動方式:Class.forName(“com.mysql.jdbc.Driver”);
採用此種方式不會導致驅動對象在記憶體中重複出現,並且採用此種方式,程式僅僅只需要一個字串,不需要依賴具體的驅動,使程式的靈活性更高。
3. 同樣,在開發中也不建議採用具體的驅動類型指向getConnection方法返回的connection對象。
程式詳解—資料庫URL
1. URL用於標識資料庫的位置,程式員通過URL地址告訴JDBC程式串連哪個資料庫,URL的寫法為:
jdbc:mysql://localhost:3306/test?參數名:參數值
協議 子協議 主機:連接埠 資料庫 參數
2.常用資料庫URL地址的寫法:
2.1 Oracle:jdbc:oracle:thin:@localhost:1521:sid
2.2 SqlServer:jdbc:microsoft:sqlserver://localhost:1433; DatabaseName=sid
2.3 MySql:jdbc:mysql://localhost:3306/sid
Mysql的url地址的簡寫形式: jdbc:mysql:///sid
2.4 常用屬性:useUnicode=true&characterEncoding=UTF-8
程式詳解—Connection
1. Jdbc程式中的Connection,它用於代表資料庫的連結,Collection是資料庫編程中最重要的一個對象,用戶端與資料庫所有互動都是通過connection對象完成的,這個對象的常用方法:
createStatement():建立向資料庫發送sql的statement對象
prepareStatement(sql) :建立向資料庫發送先行編譯sql的PrepareSatement對象
預存程序
prepareCall(sql):建立執行預存程序的callableStatement對象。
事務
setAutoCommit(boolean autoCommit):設定事務是否自動認可。
commit() :在連結上提交事務。
rollback() :在此連結上復原事務
程式詳解-Statement
1. Jdbc程式中的Statement對象用於向資料庫發送SQL語句, Statement對象常用方法:
1.1 執行SQL語句
executeQuery(String sql) :用於向資料發送查詢語句,返回ResultSet結果集
executeUpdate(String sql):用於向資料庫發送insert、update或delete語句,返回int,受影響的記錄
execute(String sql):用於向資料庫發送任意sql語句,返回bool
1.2 支援批處理,一次性執行多條SQL
addBatch(String sql) :把多條sql語句放到一個批處理中。
executeBatch():向資料庫發送一批sql語句執行。
程式詳解-PreparedStatement
1. PreperedStatement是Statement的子類,它的執行個體對象可以通過調用Connection.preparedStatement()方法獲得,相對於Statement對象而言:
2. PreperedStatement可以避免SQL注入的問題。
3. Statement會使資料庫頻繁編譯SQL,可能造成資料庫緩衝區溢位。PreparedStatement 可對SQL進行先行編譯,從而提高資料庫的執行效率並且PreperedStatement對於sql中的參數,允許使用預留位置的形式進行替換,簡化sql語句的編寫。
例如:
String sql="select * from users where name=? and pwd=?";
try{
PreparedStatement pstmt=conn.prepareStatement(sql);
pstmt.setString(1,userName);
pstmt.setString(1,password);
ResultSet rs=pstmt.executeQuery();
}
備忘:
(1). 必須在獲得PrepareStatement對象時,傳入SQL進行先行編譯
(2). 傳值,索引從1開始
(3). pstmt執行SQL的時候,一定不要將先行編譯的SQL傳入,否則會出錯
程式詳解-ResultSet
1. Jdbc程式中的ResultSet用於代表Sql語句的執行結果。Resultset封裝執行結果時,採用的類似於表格的方式。ResultSet 對象維護了一個指向表格式資料行的遊標,初始的時候,遊標在第一行之前,調用ResultSet.next() 方法,可以使遊標指向具體的資料行,進而調用方法擷取該行的資料。
2.ResultSet既然用於封裝執行結果的,所以該對象提供的大部分方法都是用於擷取資料的get方法:
2.1 擷取任意類型的資料
getObject(int index)
getObject(string columnName)
2.2 擷取指定類型的資料,例如:
getString(int index)
getString(String columnName)
3. 如果rs返回一行資料,在開發中,經常使用if(rs.next())來替代while(rs.next());
4. ResultSet還提供了對結果集進行滾動的方法:
4.1 next():移動到下一行
4.2 previous():移動到前一行
4.3 absolute(int row):移動到指定行
4.4 beforeFirst():移動resultSet的最前面。
4.5 afterLast() :移動到resultSet的最後面。
程式詳解—釋放資源
1. Jdbc程式運行完後,切記要釋放程式在運行過程中,建立的那些與資料庫進行互動的對象,這些對象通常是ResultSet, Statement和Connection對象。
2. 特別是Connection對象,它是非常稀有的資源,用完後必須馬上釋放,如果Connection不能及時、正確的關閉,極易導致系統宕機。Connection的使用原則是盡量晚建立,盡量早的釋放。
3. 為確保資源釋放代碼能運行,資源釋放代碼也一定要放在finally語句中。
JDBC操作資料庫Demo
開發環境 MyEclipse
資料庫 MySql
:
Java學習筆記之_JDBC