基于JDBC訪問MySql公共方法實例解析
本來項目都是用到例如Hibernate這些工具的,可是因為現(xiàn)在項目要求現(xiàn)在又丫的回到基于JDK的解決方案了。
這個方法很簡單,但是對于數(shù)據(jù)的連接使用連接池,連接池也是直接初始化的。
package com;
import java.sql.*;
import java.util.*;
import org.apache.commons.dbcp.BasicDataSource;
/**
* @說明 數(shù)據(jù)庫連接管理
* @author cuisuqiang
*/
public class ConnectionManager {
/**
* @說明 執(zhí)行一條SQL
*/
@SuppressWarnings("unchecked")
public static List<Object[]> excuteQuery(String sql) {
Connection conn = null;
PreparedStatement psta = null;
ResultSet resultSet = null;
List<Object[]> relist = new ArrayList<Object[]>(); // 總數(shù)據(jù)
Object[] objects = null; // 每行數(shù)據(jù)
try {
conn = ConnectionManager.getConn(); // 得到鏈接
if(null != conn){
psta = conn.prepareStatement(sql);
resultSet = psta.executeQuery(); // 執(zhí)行查詢,返回結果接集合
int count = resultSet.getMetaData().getColumnCount(); // 一共有多少列數(shù)據(jù)
// 循環(huán)行
while (resultSet.next()) {
objects = new Object[count];
// 數(shù)據(jù)集索引從 1 開始,而數(shù)組存放時是從 0 開始
for (int i = 1; i <= count; i++) {
objects[i - 1] = resultSet.getObject(i);
}
relist.add(objects);
}
}
} catch (Exception e) {
e.printStackTrace();
relist = null;
} finally {
try {
if(null != resultSet)
resultSet.close();
if(null != psta)
psta.close();
if(null != conn)
conn.close();
} catch (Exception e2) {
}
}
return relist;
}
private static org.apache.commons.dbcp.BasicDataSource ds = null;
static {
ds = new BasicDataSource(); // 組建數(shù)據(jù)源對象
int initialSize = 1; // 連接池啟動時的初始值
int maxActive = 10; // 連接池的最大值
int maxIdle = 1; // 最大空閑值
int minIdle = 1; // 最小空閑值
ds.setDriverClassName("com.mysql.jdbc.Driver");
ds.setUrl("jdbc:mysql://192.168.154.128:3306/t2?useUnicode=true&characterEncoding=gbk");
ds.setUsername("root");
ds.setPassword("123456");
ds.setInitialSize(initialSize);
ds.setMaxActive(maxActive);
ds.setMaxIdle(maxIdle);
ds.setMinIdle(minIdle);
}
/**
* 從數(shù)據(jù)源中取得數(shù)據(jù)庫連接
*/
public static Connection getConn() {
try {
return ds.getConnection();
} catch (SQLException e) {
e.printStackTrace();
}
return null;
}
}
我使用的是BasicDataSource,你可能需要兩個Jar包,commons-pool.jar,commons-dbcp.jar,連接mysql的話需要mysql-connector-java-3.1.13-bin.jar。
寫一個mian方法直接測試:
package com;
import java.util.List;
public class T {
@SuppressWarnings("unchecked")
public static void main(String[] args) {
try {
List<Object[]> list = ConnectionManager.excuteQuery("select * from t");
for (int i = 0; i < list.size(); i++) {
Object[] os = list.get(i);
for(Object o : os){
if (o instanceof String) {
String s = (String) o;
String newStr = new String(s.getBytes("ISO-8859-1"),"GBK");
System.out.print("字符串:" + newStr + "\t\t");
}else if(o instanceof Long){
Long s = (Long) o;
System.out.print("浮點值:" + s + "\t\t");
}else if(o instanceof Integer){
Integer s = (Integer) o;
System.out.print("整形值:" + s + "\t\t");
}else{
System.out.print("未知型:" + o + "\t\t");
}
}
System.out.println();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
我返回的是一個List集合,里面包含了一個Object數(shù)組。調用者在收到這個返回集合后可以根據(jù)實際情況進行解析,公共方法只是執(zhí)行SQL,然后得到數(shù)據(jù)連接進行數(shù)據(jù)訪問。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Maven添加Tomcat插件實現(xiàn)熱部署代碼實例
這篇文章主要介紹了Maven添加Tomcat插件實現(xiàn)熱部署代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-04-04
SpringBoot使用Redis Stream實現(xiàn)輕量消息隊列的示例代碼
Redis Stream 是 Redis 5.0 引入的一種數(shù)據(jù)結構,用于處理日志類型的數(shù)據(jù),它提供了高效、可靠的方式來處理和存儲時間序列數(shù)據(jù),如事件、消息等,本文介紹了SpringBoot使用Redis Stream實現(xiàn)輕量消息隊列,需要的朋友可以參考下2024-08-08
SpringBoot項目中出現(xiàn)不同端口跨域問題的解決方法
這篇文章主要介紹了SpringBoot項目中出現(xiàn)不同端口跨域問題的解決方法,文中介紹了兩種解決方法,并給出了詳細的代碼供大家參考,具有一定的參考價值,需要的朋友可以參考下2024-03-03
SpringSecurity請求授權規(guī)則配置與注解詳解
這篇文章主要介紹了SpringSecurity請求授權規(guī)則配置與注解詳解,我們常使用@Secured與@PreAuthorize兩個注解在進入方法前進行角色、權限的控制,進入方法前數(shù)據(jù)的過濾@PreFilter注解偶爾會看到,需要的朋友可以參考下2023-12-12

