如何使用JDBC連接數(shù)據(jù)庫并執(zhí)行SQL語句
1. JDBC入門
JDBC(Java Database Connectivity)是Java程序與數(shù)據(jù)庫進行交互的一種標(biāo)準(zhǔn)接口,它提供了一種簡單的方式來連接和操作數(shù)據(jù)庫。在使用JDBC之前,需要先了解以下幾個概念:
- JDBC Driver:JDBC驅(qū)動程序是一個Java類,用于將Java應(yīng)用程序與特定數(shù)據(jù)庫管理系統(tǒng)(DBMS)連接。JDBC驅(qū)動程序分為四種類型:JDBC-ODBC橋接驅(qū)動程序、本地API驅(qū)動程序、網(wǎng)絡(luò)協(xié)議驅(qū)動程序和本地協(xié)議驅(qū)動程序。
- Connection:Connection是一個JDBC接口,用于連接到數(shù)據(jù)庫。在Java程序中,通過Connection接口的實現(xiàn)類來實現(xiàn)與數(shù)據(jù)庫的連接。
- Statement:Statement是一個JDBC接口,用于向數(shù)據(jù)庫發(fā)送SQL語句并執(zhí)行它們。在Java程序中,通過Connection對象創(chuàng)建Statement對象。
- ResultSet:ResultSet是一個JDBC接口,用于表示從數(shù)據(jù)庫中檢索到的結(jié)果集。ResultSet對象通過Statement對象的executeQuery()方法返回。
下面是一個簡單的JDBC連接示例:
import java.sql.*;
public class JDBCDemo {
public static void main(String[] args) {
try {
// 加載JDBC驅(qū)動程序
Class.forName("com.mysql.cj.jdbc.Driver");
// 建立數(shù)據(jù)庫連接
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "root", "password");
// 執(zhí)行SQL查詢
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM users");
while (rs.next()) {
System.out.println(rs.getInt(1) + ", " + rs.getString(2) + ", " + rs.getString(3));
}
// 關(guān)閉數(shù)據(jù)庫連接
rs.close();
stmt.close();
conn.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
2. 抽取工具類
在實際開發(fā)中,我們通常會抽取出一個JDBC工具類來封裝JDBC相關(guān)操作,以方便代碼的重用和維護。下面是一個簡單的JDBC工具類示例:
import java.sql.*;
public class JDBCUtils {
private static final String URL = "jdbc:mysql://localhost:3306/mydb";
private static final String USER = "root";
private static final String PASSWORD = "password";
static {
try {
// 加載JDBC驅(qū)動程序
Class.forName("com.mysql.cj.jdbc.Driver");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
public static Connection getConnection() {
Connection conn = null;
try {
// 建立數(shù)據(jù)庫連接
conn = DriverManager.getConnection(URL, USER, PASSWORD);
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
public static void release(ResultSet rs, Statement stmt, Connection conn) {
try {
if (rs != null) rs.close();
if (stmt != null) stmt.close();
if (conn != null) conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}3. Statement CRUD
Statement是JDBC中最基本的操作方式,它用于向數(shù)據(jù)庫發(fā)送SQL語句并執(zhí)行它們。下面是一個使用Statement進行CRUD操作的示例:
import java.sql.*;
public class StatementCRUD {
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
try {
conn = JDBCUtils.getConnection();
stmt = conn.createStatement();
// 插入數(shù)據(jù)
String sql = "INSERT INTO users (name, age) VALUES ('Tom', 18)";
stmt.executeUpdate(sql);
// 更新數(shù)據(jù)
sql = "UPDATE users SET age = 20 WHERE name = 'Tom'";
stmt.executeUpdate(sql);
// 刪除數(shù)據(jù)
sql = "DELETE FROM users WHERE age = 20";
stmt.executeUpdate(sql);
// 查詢數(shù)據(jù)
sql = "SELECT * FROM users";
rs = stmt.executeQuery(sql);
while (rs.next()) {
System.out.println(rs.getInt(1) + ", " + rs.getString(2) + ", " + rs.getInt(3));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtils.release(rs, stmt, conn);
}
}
}4. 演練CRUD
下面是一個使用PreparedStatement進行CRUD操作的示例:
import java.sql.*;
public class PreparedStatementCRUD {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
conn = JDBCUtils.getConnection();
// 插入數(shù)據(jù)
String sql = "INSERT INTO users (name, age) VALUES (?, ?)";
pstmt = conn.prepareStatement(sql);
pstmt.setString(1, "Tom");
pstmt.setInt(2, 18);
pstmt.executeUpdate();
// 更新數(shù)據(jù)
sql = "UPDATE users SET age = ? WHERE name = ?";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, 20);
pstmt.setString(2, "Tom");
pstmt.executeUpdate();
// 刪除數(shù)據(jù)
sql = "DELETE FROM users WHERE age = ?";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, 20);
pstmt.executeUpdate();
// 查詢數(shù)據(jù)
sql = "SELECT * FROM users";
pstmt = conn.prepareStatement(sql);
rs = pstmt.executeQuery();
while (rs.next()) {
System.out.println(rs.getInt(1) + ", " + rs.getString(2) + ", " + rs.getInt(3));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtils.release(rs, pstmt, conn);
}
}
}5. Dao模式(聲明與實現(xiàn)分開)
Dao(Data Access Object)模式是一種用于封裝數(shù)據(jù)訪問邏輯的設(shè)計模式。它將數(shù)據(jù)訪問邏輯與業(yè)務(wù)邏輯分離開來,使得代碼更易于維護和擴展。下面是一個使用Dao模式進行CRUD操作的示例:
import java.sql.*;
public class UserDAO {
private static final String INSERT_SQL = "INSERT INTO users (name, age) VALUES (?, ?)";
private static final String UPDATE_SQL = "UPDATE users SET age = ? WHERE name = ?";
private static final String DELETE_SQL = "DELETE FROM users WHERE age = ?";
private static final String SELECT_SQL = "SELECT * FROM users";
public void insert(User user) {
Connection conn = null;
PreparedStatement pstmt = null;
try {
conn = JDBCUtils.getConnection();
pstmt = conn.prepareStatement(INSERT_SQL);
pstmt.setString(1, user.getName());
pstmt.setInt(2, user.getAge());
pstmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtils.release(null, pstmt, conn);
}
}
public void update(User user) {
Connection conn = null;
PreparedStatement pstmt = null;
try {
conn = JDBCUtils.getConnection();
pstmt = conn.prepareStatement(UPDATE_SQL);
pstmt.setInt(1, user.getAge());
pstmt.setString(2, user.getName());
pstmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtils.release(null, pstmt, conn);
}
}
public void delete(int age) {
Connection conn = null;
PreparedStatement pstmt = null;
try {
conn = JDBCUtils.getConnection();
pstmt = conn.prepareStatement(DELETE_SQL);
pstmt.setInt(1, age);
pstmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtils.release(null, pstmt, conn);
}
}
public List<User> selectAll() {
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
List<User> userList = new ArrayList<>();
try {
conn = JDBCUtils.getConnection();
pstmt = conn.prepareStatement(SELECT_SQL);
rs = pstmt.executeQuery();
while (rs.next()) {
User user = new User();
user.setId(rs.getInt(1));
user.setName(rs.getString(2));
user.setAge(rs.getInt(3));
userList.add(user);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtils.release(rs, pstmt, conn);
}
return userList;
}
}
public class User {
private int id;
private String name;
private int age;
// 省略getter、setter方法
}6. PrepareStatement CRUD
PreparedStatement是一種預(yù)編譯的Statement,它可以通過占位符的方式來替換SQL語句中的參數(shù),避免了SQL注入的危險。下面是一個使用PreparedStatement進行CRUD操作的示例:
import java.sql.*;
public class PrepareStatementCRUD {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
conn = JDBCUtils.getConnection();
// 插入數(shù)據(jù)
String sql = "INSERT INTO users (name, age) VALUES (?, ?)";
pstmt = conn.prepareStatement(sql);
pstmt.setString(1, "Tom");
pstmt.setInt(2, 18);
pstmt.executeUpdate();
// 更新數(shù)據(jù)
sql = "UPDATE users SET age = ? WHERE name = ?";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, 20);
pstmt.setString(2, "Tom");
pstmt.executeUpdate();
// 刪除數(shù)據(jù)
sql = "DELETE FROM users WHERE age = ?";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, 20);
pstmt.executeUpdate();
// 查詢數(shù)據(jù)
sql = "SELECT * FROM users";
pstmt = conn.prepareStatement(sql);
rs = pstmt.executeQuery();
while (rs.next()) {
System.out.println(rs.getInt(1) + ", " + rs.getString(2) + ", " + rs.getInt(3));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtils.release(rs, pstmt, conn);
}
}
}以上就是關(guān)于JDBC入門、抽取工具類、Statement CRUD、演練CRUD、Dao模式(聲明與實現(xiàn)分開)、PrepareStatement CRUD的詳細介紹和代碼示例。通過學(xué)習(xí)這些內(nèi)容,可以讓我們更好地掌握JDBC的使用和開發(fā)技巧,從而更好地應(yīng)用到實際的項目中。
到此這篇關(guān)于如何使用JDBC連接數(shù)據(jù)庫并執(zhí)行SQL語句的文章就介紹到這了,更多相關(guān)JDBC連接數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java Enum和String及int的相互轉(zhuǎn)化示例
這篇文章主要介紹了Java Enum和String及int的相互轉(zhuǎn)化示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
Java實現(xiàn)讀取Excel文件功能(EasyExcel初使用)
EasyExcel是一款基于Java語言的開源Excel解析工具,可以幫助我們快速、高效地讀取和寫入Excel文件,這篇文章主要給大家介紹了關(guān)于Java實現(xiàn)讀取Excel文件功能的相關(guān)資料,使用的是EasyExcel,需要的朋友可以參考下2024-07-07
Java中的排序與內(nèi)部比較器Compareable解析
這篇文章主要介紹了Java中的排序與內(nèi)部比較器Compareable解析,一般沒有特殊要求時,直接調(diào)用(底層默認的升序排列)就可以得到想要的結(jié)果,所謂的 sort 方法排序底層都是基于這兩種排序,故如果需要設(shè)計成所想要的排序就需要了解底層排序原理,需要的朋友可以參考下2023-11-11
詳解MyBatis Generator自動創(chuàng)建代碼(dao,mapping,poji)
這篇文章主要介紹了詳解MyBatis Generator自動創(chuàng)建代碼(dao,mapping,poji)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-10-10

