資料庫工具類實現
資料庫工具類實現
對資料庫資源進行統一申請和釋放,易於管理與使用,本例中對資料庫連線的獲取使用的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();
}
}
}
相關文章
- 寫一個工具生成資料庫實體類資料庫
- 帶你實現一個簡單的MYSQL資料庫生成實體類工具MySql資料庫
- 阿里Druid資料庫連線工具類阿里UI資料庫
- 策略模式實現支援多種類資料庫的DBHelp模式資料庫
- 實現一個CRDT工具庫——VClock 時鐘向量類
- 資料庫連線池_druid基本使用&工具類資料庫UI
- 通過sysbench工具實現MySQL資料庫的效能測試MySql資料庫
- iOS - 最易用的資料庫工具類 XWDatabase 開源iOS資料庫Database
- 資料庫連線池實現資料庫
- Redis多機資料庫實現Redis資料庫
- 如何實現資料庫資料到Abp vnext實體物件的同步?以及程式碼生成工具資料庫物件
- java 如何從零實現一個資料庫差異對比工具?Java資料庫
- CAS配置資料庫,實現資料庫使用者認證資料庫
- 資料庫用途分類資料庫
- 四類NoSQL資料庫SQL資料庫
- Java 工具類庫Java
- Android工具類庫Android
- springboot結合Redis實現工具類Spring BootRedis
- django使用多個資料庫實現Django資料庫
- Mybatis實現分包定義資料庫MyBatis資料庫
- 資料庫實現原理#4(Hash Join)資料庫
- Redis 設計與實現:資料庫Redis資料庫
- golang實現mysql資料庫備份GolangMySql資料庫
- 實現MySQL資料庫的實時備份MySql資料庫
- laravel實現100w大量資料插入資料庫Laravel資料庫
- mybatis 實體類排除資料庫欄位對映MyBatis資料庫
- 《redis設計與實現》2-資料庫實現篇Redis資料庫
- 資料庫分類有哪些資料庫
- [資料庫]000 - ?Sysbench 資料庫壓力測試工具資料庫
- spring boot 結合Redis 實現工具類Spring BootRedis
- Excel資料庫轉MySQL,實現查詢Excel資料庫MySql
- 資料庫向量化入門與實現資料庫
- mysql資料庫實現主從複製MySql資料庫
- 實現報表資料分庫儲存
- 資料庫實現原理#1(Nested Loop Join)資料庫OOP
- 資料庫實現原理#3(Merge Join).md資料庫
- 【JDBC的實現步驟……MySQL資料庫】JDBCMySql資料庫
- Redis 資料庫、鍵過期的實現Redis資料庫
- 讓業務實現迴歸資料庫資料庫