《Tomcat與Java Web開發技術詳解》閱讀梳理 第八章 訪問資料庫
JDBC
JDBC(java DataBase Connectivity)是java與資料庫連線的紐帶。JDBC封裝了java與資料庫通訊的細節。程式設計師只需要通過JDBC API就可以與資料庫伺服器通訊。
優點:
1.簡化程式碼
2.使java程式碼不依賴具體資料庫伺服器。
JDBC API位於java.sql(大部分)和javax.sql(高階特性)包中。
JDBC的實現
JDBC的實現包括三個部分
1.JDBC驅動管理器:java.sql.DriverManger類,由Oracle公司實現,負責註冊特定JDBC驅動器,以及根據特定驅動器建立與資料庫的連線。
2.JDBC驅動器API:由Oracle公司制定,其中最主要的介面是java.sql.Driver介面。
3.JDBC驅動器,由資料庫供應商,或者其他第三方工具提供商建立,也成為JDBC驅動程式。JDBC驅動器實現了JDBC驅動器API負責與與特定資料庫連線。
JDBC API:java程式通過它來訪問各種資料庫。
JDBC驅動器 API:具體的JDBC驅動器需要實現它(java.sql.Driver)
因此實際上java程式與資料庫伺服器的連線是由JDBC驅動器完成的。
橋樑設計模式
DriverManager類運用橋樑設計模式,是java程式與各種JDBC驅動器連線的橋樑。
應用程式只和JDBC API打交道,JDBC API依賴DriverManager類來管理JDBC驅動器。
java.sql包中的介面和類
JDBC API主要在java.sql包中,主要有
1.Driver介面:驅動器
2.DriverManager類:驅動管理器
3.Connection介面:表示資料庫連線
4.Statement介面:負責執行SQL語句
5.PreparedStatement介面:負責執行預準備的SQL語句
6.CallableStatement介面:負責執行SQL儲存過程。
7.ResultSet介面:表示SQL查詢語句返回的結果集。
DRiverManager類方法
Connection介面方法
Statement介面
PrepareStatement介面方法
PrepareStatement是statement的子介面,statement執行的sql語句引數都是固定的。而prepareStatement的引數可以動態修改。每次通過statement執行sql語句都要重新編譯。而prepareStatement只需編譯一次,然後可以多次執行。
例子
PreparedStatement
PreparedStatement preparedStatement = connection.prepareStatement("select id,username,? from user where id = ?");
//第一個?是password
preparedStatement.setString(1,"password");
//第二個?是10
preparedStatement.setInt(2,2);
Statement
Statement statement = connection.createStatement();
statement.execute("select * from user where id = 10");
ResultSet介面的方法
ResultSet介面表示select查詢語句得到的結果集。
while (resultSet.next()){
//根據索引
System.out.println(resultSet.getString(1));
//根據欄位名
System.out.println(resultSet.getString("username"));
}
訪問資料庫程式的步驟
1.載入JDBC驅動器
Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
2.註冊資料庫驅動器
DriverManager.registerDriver((Driver) aClass.newInstance());
這一步實際上並不是必須的
因為在com.mysql.cj.jdbc.Driver內部有這麼一段靜態程式碼
static {
try {
DriverManager.registerDriver(new Driver());
} catch (SQLException var1) {
throw new RuntimeException("Can't register driver!");
}
}
他實際上會在載入的時候就自己把自己註冊了
3.與資料庫建立連線
String url = "jdbc:mysql://localhost:3306/db1";
Connection connection = DriverManager.getConnection(url,"root","root");
url的格式
jdbc:[資料庫名]:[資料庫伺服器IP]:[埠號]/[資料庫名]?[預設配置]
完整例子
//1.載入並註冊驅動
Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
//DriverManager.registerDriver((Driver) aClass.newInstance());
//2.與資料庫建立連線
String url = "jdbc:mysql://localhost:3306/db1";
Connection connection = DriverManager.getConnection(url,"root","root");
//3.用PreparedStatement
PreparedStatement preparedStatement = connection.prepareStatement("select id,username,? from user where id = ?");
//第一個?是password
preparedStatement.setString(1,"password");
//第二個?是10
preparedStatement.setInt(2,2);
preparedStatement.execute();
//獲取ResultSet物件
ResultSet resultSet1 = preparedStatement.getResultSet();
while (resultSet1.next()){
//根據索引
System.out.println(resultSet1.getInt(1));
//根據欄位名
System.out.println(resultSet1.getString("username"));
//根據索引
System.out.println(resultSet1.getString(3));
}
//3.用statement
Statement statement = connection.createStatement();
statement.execute("select id,username,password from user where id = 9");
//獲取ResultSet物件
ResultSet resultSet = statement.getResultSet();
while (resultSet.next()){
//根據索引
System.out.println(resultSet.getInt(1));
//根據欄位名
System.out.println(resultSet.getString("username"));
//根據索引
System.out.println(resultSet.getString(3));
}
事務處理
所謂事務,就是多條SQL語句組合而成的。這些SQL語句要麼都成功完成,要麼都失敗。也就是說即使有一個SQL語句執行出現錯誤,這個事務中的所有SQL都將失效
在Connection介面中提供了三個控制事務的方法
1.serAutoCommit(boolean autoCommit);設定是否自動提交事務。預設情況下為true。也就是說每條SQL語句執行成功後自動提交,失敗則自動回滾。
2.commit();提交事務
3.rollback():回滾事務
例子
//1.載入並註冊驅動
Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
//DriverManager.registerDriver((Driver) aClass.newInstance());
//2.與資料庫建立連線
String url = "jdbc:mysql://localhost:3306/db1";
Connection connection = DriverManager.getConnection(url,"root","root");
//禁止自動提交事務
connection.setAutoCommit(false);
Statement statement1 = connection.createStatement();
try{
statement1.executeUpdate("update user set password = 'heh213e1' where id = 2");
statement1.executeUpdate("update user set password = heh213e1 where id = 2");
connection.commit();
}catch (SQLException e){
//事務回滾
connection.rollback();
}
配置資料來源
context.xml
<?xml version="1.0" encode="UTF-8" ?>
<Context>
<!-- T9.0 將resource複製到tomcat/config/context的Context中-->
<Resource
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/db1"
username="root"
password="root"
maxActive="50"
maxIdle="20"
name="ds"
auth="Container"
maxWait="10000"
type="javax.sql.DataSource"/>
</Context>
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
<resource-ref>
<description>DB Connection</description>
<res-ref-name>ds</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</web-app>
@WebServlet("/test3")
public class Test3 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req,resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
Connection connection =null;
try {
InitialContext context = new InitialContext();
DataSource ds = (DataSource) context.lookup("java:comp/env/ds");
connection = ds.getConnection();
Statement statement = connection.createStatement();
statement.execute("select id,username.password from user ");
ResultSet resultSet = statement.getResultSet();
while(resultSet.next()){
System.out.println(resultSet.getInt(1));
System.out.println(resultSet.getString(2));
System.out.println(resultSet.getString(3));
}
} catch (NamingException e) {
e.printStackTrace();
} catch (SQLException throwables) {
throwables.printStackTrace();
} finally {
try {
connection.close();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
}
}
可滾動的結果級
//建立一個可以生成可以滾動的結果集的statemen
Statement statement = connection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
相關文章
- 基於gin的golang web開發:訪問mysql資料庫GolangWebMySql資料庫
- 開源了!RadonDB分散式資料庫核心技術與實現詳解分散式資料庫
- 解讀圖資料庫技術路線資料庫
- Web開發技術選型之Java與PHPWebJavaPHP
- 資料庫連線池技術詳解資料庫
- OPPO雲資料庫訪問服務技術揭祕資料庫
- 解讀什麼是遠端訪問技術
- java核心技術閱讀筆記Java筆記
- Java RMI技術詳解與案例分析Java
- 解決資料庫高併發訪問瓶頸問題資料庫
- 資料庫技術解讀之細粒度資源管控資料庫
- Web除錯技術詳解Web除錯
- web前端技術Mongoose詳解Web前端Go
- 技術解讀資料庫如何實現“多租戶”?資料庫
- 資料庫大牛李海翔詳解全域性讀一致性技術資料庫
- web3.0系統開發技術詳細介紹與分析Web
- Cube 技術解讀 | Cube 小程式技術詳解
- Cube 技術解讀 | Cube 卡片技術棧詳解
- 深度解讀資料庫引入LLVM技術後如何提升效能資料庫LVM
- Xamarin SQLite教程資料庫訪問與生成SQLite資料庫
- web開發的跨域問題詳解Web跨域
- 【Tomcat】Tomcat原始碼閱讀之StandardHost與HostConfig的分析Tomcat原始碼
- Web技術與PDM產品資料管理Web
- Java訪問資料庫的具體步驟:Java資料庫
- Web開發基本準則 , Web訪問安全Web
- 解讀 AI 引擎 MindSpore 開發實踐與技術細節AI
- JDBC資料庫訪問JDBC資料庫
- 詳解Android資料儲存技術Android
- [開源] .Net ORM 訪問 Firebird 資料庫ORM資料庫
- GaussDB技術解讀系列:資料庫遷移創新實踐資料庫
- Java核心技術梳理-類載入機制與反射Java反射
- 《資料探勘概念與技術》第八章 分類:基本概念
- iOS 靜態庫詳解與開發iOS
- Java網路程式設計與NIO詳解10:深度解讀Tomcat中的NIO模型Java程式設計Tomcat模型
- 七、資料庫技術的發展及新技術資料庫
- 大資料怎麼學?對大資料開發領域及崗位的詳細解讀,完整理解大資料開發領域技術體系大資料
- 大資料技術Hbase和Hive詳解大資料Hive
- 3.2.4 開啟資料庫到限制訪問模式資料庫模式