這篇文章主要介紹了java 使用策略模式操作JDBC資料庫的相關資料,這裡提供實例實現對JDBC資料庫的操作增刪改查的功能,需要的朋友可以參考下
java 使用策略模式操作JDBC資料庫
1:建構一個操作資料庫的工具類,可以取得連接和釋放連接
public class DBUtil { private static Connection conn = null; static { //静态初始块 try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test", "root", "064319"); //初始化获取连接 } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } } /** * 释放连接 * @param rs * @param psmt * @param conn * @throws SQLException */ public static void closeAll(ResultSet rs, PreparedStatement psmt, Connection conn) throws SQLException { if(rs != null) { rs.close(); } if(psmt != null) { psmt.close(); } if(conn != null) { conn.close(); } } /** * 获取连接 * @return */ public static Connection getConnection() { return conn; } /** * 根据表的名字来获得表的列信息 * @param tableName */ public static void getTableColumnInfoByTableName(String tableName) { Connection conn = getConnection(); ResultSet rs = null; PreparedStatement psmt = null; String sql = "select * from " + tableName; try { psmt = conn.prepareStatement(sql); rs = psmt.executeQuery(); ResultSetMetaData resultSetMetaData = rs.getMetaData(); for(int i = 1; i<= resultSetMetaData.getColumnCount(); i++) { System.out.println(resultSetMetaData.getColumnName(i)); } } catch (SQLException e) { e.printStackTrace(); } finally { try { closeAll(rs, psmt, conn); } catch (SQLException e) { e.printStackTrace(); } } } /** * 根据表的名字来获得表的信息 * @param tableName */ public static void getTableInfoByTableName(String tableName) { Connection conn = getConnection(); PreparedStatement psmt = null; ResultSet rs = null; String sql = "select * from " + tableName; try { psmt = conn.prepareStatement(sql); rs = psmt.executeQuery(); while(rs.next()) { ResultSetMetaData resultSetMetaData = rs.getMetaData(); for(int i = 1; i<= resultSetMetaData.getColumnCount(); i++) { if(i < resultSetMetaData.getColumnCount()) { System.out.print(rs.getObject(resultSetMetaData.getColumnName(i)) + ", "); } else { System.out.print(rs.getObject(resultSetMetaData.getColumnName(i))); } } System.out.println(); } } catch (SQLException e) { e.printStackTrace(); } finally { try { closeAll(rs, psmt, conn); } catch (SQLException e) { e.printStackTrace(); } } } }
2:建構一個操作資料庫的BaseDao類
public class BaseDao { /** * 根据一些参数来保存相应的对象 * @param sql 要执行的sql语句 * @param params 为sql语句中相应的参数赋值 * @return */ protected boolean saveOrUpdate(String sql, Object[] params) { Connection conn = null; PreparedStatement psmt = null; boolean flag = false; conn = DBUtil.getConnection(); if(conn != null) { try { psmt = conn.prepareStatement(sql); for(int i = 1; i <= params.length; i++) { psmt.setObject(i, params[i-1]); } if(psmt.executeUpdate() > 0) { flag = true; } } catch (SQLException e) { e.printStackTrace(); } finally { try { DBUtil.closeAll(null, psmt, conn); } catch (SQLException e) { e.printStackTrace(); } } } return flag; } /** * 根据一定的参数获得某个具体的对象 * @param sql 要执行的sql语句 * @param params 为sql语句中相应的参数赋值 * @return */ public Object queryForObject(String sql, Object[] params, RowMapForObject rowMapForObject) { Connection conn = null; PreparedStatement psmt = null; conn = DBUtil.getConnection(); Object obj = null; ResultSet rs = null; if(conn != null) { try { psmt = conn.prepareStatement(sql); if(params != null && params.length > 0) { for(int i = 1; i <= params.length; i++) { psmt.setObject(i, params[i - 1]); } } rs = psmt.executeQuery(); obj = rowMapForObject.rowMapForObject(rs); } catch (SQLException e) { e.printStackTrace(); } finally { try { DBUtil.closeAll(null, psmt, conn); } catch (SQLException e) { e.printStackTrace(); } } } return obj; } /** * 根据相应的参数获得查询的结果集 * @param sql * @param params * @return */ public List queryForList(String sql, Object[] params, RowMapForList rowMapForList) { Connection conn = null; PreparedStatement psmt = null; conn = DBUtil.getConnection(); List list = null; ResultSet rs = null; if(conn != null) { try { psmt = conn.prepareStatement(sql); if(params != null && params.length > 0) { for(int i = 1; i <= params.length; i++) { psmt.setObject(i, params[i - 1]); } } rs = psmt.executeQuery(sql); list = new ArrayList(); list = rowMapForList.rowMapForList(rs); } catch (SQLException e) { e.printStackTrace(); } finally { try { DBUtil.closeAll(null, psmt, conn); } catch (SQLException e) { e.printStackTrace(); } } } return list; } }
3:新建一個StudentDao類,該類別繼承自BaseDao,實作對Student的管理
public class StudentDao extends BaseDao { /** * 保存一个Student的信息 */ public boolean saveStudent(Student student) { String sql = "insert into t_student(name, age) values(?, ?)"; Object[] params = new Object[]{student.getName(), student.getAge()}; return super.saveOrUpdate(sql, params); } /** * 根据id获得一个Student的信息 * @param id * @return */ public Student getStudentById(long id) { String sql = "select * from t_student where id=?"; Object[] params = new Object[]{id}; return (Student)super.queryForObject(sql, params, new RowMapForObject() { public Object rowMapForObject(ResultSet rs) { Student student = null; try { if(rs != null && rs.next()) { student = new Student(); student.setAge(rs.getInt(Student.AGE)); student.setId(rs.getLong(Student.ID)); student.setName(rs.getString(Student.NAME)); } } catch (SQLException e) { e.printStackTrace(); } return student; } }); } /** * 获得所有Student的信息 * @return */ public List getStudentAll() { String sql = "select * from t_student"; List list = super.queryForList(sql, null, new RowMapForList() { @Override public List rowMapForList(ResultSet rs) { List list = null; try { if(rs != null) { list = new ArrayList(); while(rs.next()) { Student student = new Student(); student.setId(rs.getLong("id")); student.setAge(rs.getInt("age")); student.setName(rs.getString("name")); list.add(student); } } } catch(SQLException e) { e.printStackTrace(); } return list; } }); return list; } }
以上是Java如何利用策略模式操作JDBC資料庫的實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Atom編輯器mac版下載
最受歡迎的的開源編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)