資料庫工具類實現
資料庫工具類實現
對資料庫資源進行統一申請和釋放,易於管理與使用,本例中對資料庫連線的獲取使用的c3p0的資料庫連線池,詳情可觀本部落格另一篇介紹
package com.Android.util;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class JdbcUtil {
// 定義資料庫的連結
private Connection connection;
// 定義sql語句的執行物件
private PreparedStatement pstmt;
// 定義查詢返回的結果集合
private ResultSet resultSet;
public JdbcUtil() {
//從資料庫獲取資料庫連線
connection = ConnectionManager.getInstance().getConnection();
}
/**
* 執行更新操作
*
* @param sql
* sql語句
* @param params
* 執行引數
* @return 執行結果
* @throws SQLException
*/
public boolean updateByPreparedStatement(String sql, List<?> params)
throws SQLException {
boolean flag = false;
int result = -1;// 表示當使用者執行新增刪除和修改的時候所影響資料庫的行數
pstmt = connection.prepareStatement(sql);
int index = 1;
// 填充sql語句中的佔位符
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
result = pstmt.executeUpdate();
flag = result > 0 ? true : false;
return flag;
}
/**
* 執行查詢操作
*
* @param sql
* sql語句
* @param params
* 執行引數
* @return
* @throws SQLException
*/
public List<Map<String, Object>> findResult(String sql, List<?> params)
throws SQLException {
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
int index = 1;
pstmt = connection.prepareStatement(sql);
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
resultSet = pstmt.executeQuery();
ResultSetMetaData metaData = resultSet.getMetaData();
int cols_len = metaData.getColumnCount();
while (resultSet.next()) {
Map<String, Object> map = new HashMap<String, Object>();
for (int i = 0; i < cols_len; i++) {
String cols_name = metaData.getColumnName(i + 1);
Object cols_value = resultSet.getObject(cols_name);
if (cols_value == null) {
cols_value = "";
}
map.put(cols_name, cols_value);
}
list.add(map);
}
return list;
}
/**
* 執行查詢操作
*
* @param sql
* sql語句
* @param params
* 執行引數
* @return
* @throws SQLException
*/
public List findResultToBeanList(String sql, List<?> params, Class<?> cls )
throws SQLException {
List<?> list = null;
int index = 1;
pstmt = connection.prepareStatement(sql);
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
resultSet = pstmt.executeQuery();
try {
list = GetData.resultSetToList(resultSet, cls);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
}
/**
* 執行查詢操作
*
* @param sql
* sql語句
* @param params
* 執行引數
* @return
* @throws SQLException
*/
public int findResultTotalNumber(String sql, List<?> params )
throws SQLException {
int totalNumber = 0;
int index = 1;
pstmt = connection.prepareStatement(sql);
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
resultSet = pstmt.executeQuery();
try {
if(resultSet.next()){
totalNumber = resultSet.getInt(1);
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return totalNumber;
}
/**
* 釋放資源
*/
public void releaseConn() {
if (resultSet != null) {
try {
resultSet.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (pstmt != null) {
try {
pstmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (connection != null) {
try {
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) {
JdbcUtil jdbcUtil = new JdbcUtil();
try {
List<Map<String, Object>> result = jdbcUtil.findResult(
"select * from newsTable", null);
for (Map<String, Object> m : result) {
System.out.println(m);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
jdbcUtil.releaseConn();
}
}
}
相關文章
- PHP常用操作類實現——資料庫操作類PHP資料庫
- 寫一個工具生成資料庫實體類資料庫
- Android實用的SQLite資料庫工具類AndroidSQLite資料庫
- 帶你實現一個簡單的MYSQL資料庫生成實體類工具MySql資料庫
- C# SQLiteHelper類似SqlHelper類實現存取Sqlite資料庫C#SQLite資料庫
- 資料庫訪問抽象類實現專案資料庫靈活切換資料庫抽象
- MySQL資料庫工具類之——DataTable批量加入MySQL資料庫(Net版)MySql資料庫
- 策略模式實現支援多種類資料庫的DBHelp模式資料庫
- No-PDO-Models-MySQL資料庫層抽象類 – 實現MySql資料庫抽象
- 阿里Druid資料庫連線工具類阿里UI資料庫
- 實現一個CRDT工具庫——VClock 時鐘向量類
- 通過sysbench工具實現MySQL資料庫的效能測試MySql資料庫
- iOS - 最易用的資料庫工具類 XWDatabase 開源iOS資料庫Database
- 資料庫連線池_druid基本使用&工具類資料庫UI
- Redis多機資料庫實現Redis資料庫
- 使用dta 實用工具優化資料庫優化資料庫
- java 如何從零實現一個資料庫差異對比工具?Java資料庫
- CAS配置資料庫,實現資料庫使用者認證資料庫
- 資料泵實現資料遷移到異地庫
- 四類NoSQL資料庫SQL資料庫
- 資料庫幫助類資料庫
- Java 工具類庫Java
- 資料庫實現原理#4(Hash Join)資料庫
- Mybatis實現分包定義資料庫MyBatis資料庫
- 讓業務實現迴歸資料庫資料庫
- Redis 設計與實現:資料庫Redis資料庫
- django使用多個資料庫實現Django資料庫
- golang實現mysql資料庫備份GolangMySql資料庫
- JDBC資料庫連線池實現JDBC資料庫
- 資料庫的最簡單實現資料庫
- 實現MySQL資料庫的實時備份MySql資料庫
- 如何實現資料庫資料到Abp vnext實體物件的同步?以及程式碼生成工具資料庫物件
- 實現Oracle對ldap資料的各類操作OracleLDA
- 值得收藏的 ViewHolder 工具類實現View
- 資料庫遷移工具資料庫
- 《redis設計與實現》2-資料庫實現篇Redis資料庫
- MySQL資料庫備份種類以及常用備份工具彙總MySql資料庫
- MySQL 資料庫備份種類以及常用備份工具彙總MySql資料庫