基于JDBC訪問MySql公共方法實(shí)例解析
本來項(xiàng)目都是用到例如Hibernate這些工具的,可是因?yàn)楝F(xiàn)在項(xiàng)目要求現(xiàn)在又丫的回到基于JDK的解決方案了。
這個(gè)方法很簡(jiǎn)單,但是對(duì)于數(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í)行查詢,返回結(jié)果接集合 int count = resultSet.getMetaData().getColumnCount(); // 一共有多少列數(shù)據(jù) // 循環(huán)行 while (resultSet.next()) { objects = new Object[count]; // 數(shù)據(jù)集索引從 1 開始,而數(shù)組存放時(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ù)源對(duì)象 int initialSize = 1; // 連接池啟動(dòng)時(shí)的初始值 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,你可能需要兩個(gè)Jar包,commons-pool.jar,commons-dbcp.jar,連接mysql的話需要mysql-connector-java-3.1.13-bin.jar。
寫一個(gè)mian方法直接測(cè)試:
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("浮點(diǎn)值:" + 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(); } } }
我返回的是一個(gè)List集合,里面包含了一個(gè)Object數(shù)組。調(diào)用者在收到這個(gè)返回集合后可以根據(jù)實(shí)際情況進(jìn)行解析,公共方法只是執(zhí)行SQL,然后得到數(shù)據(jù)連接進(jìn)行數(shù)據(jù)訪問。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Springboot引入攔截器并放行swagger代碼實(shí)例
這篇文章主要介紹了Springboot引入攔截器并放行swagger代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11maven插件assembly使用及springboot啟動(dòng)腳本start.sh和停止腳本 stop.sh
這篇文章主要介紹了maven插件assembly使用及springboot啟動(dòng)腳本start.sh和停止腳本 stop.sh的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08Java線程池的幾種實(shí)現(xiàn)方法及常見問題解答
下面小編就為大家?guī)硪黄狫ava線程池的幾種實(shí)現(xiàn)方法及常見問題解答。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05java基于mongodb實(shí)現(xiàn)分布式鎖的示例代碼
本文主要介紹了java基于mongodb實(shí)現(xiàn)分布式鎖,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08淺析Java8新特性Lambda表達(dá)式和函數(shù)式接口
Lambda表達(dá)式理解為是 一段可以傳遞的代碼。最直觀的是使用Lambda表達(dá)式之后不用再寫大量的匿名內(nèi)部類,簡(jiǎn)化代碼,提高了代碼的可讀性2017-08-08Java判斷一個(gè)字符串是不是一個(gè)數(shù)字的解決思路
這篇文章主要給大家介紹了關(guān)于Java判斷一個(gè)字符串是不是一個(gè)數(shù)字的解決思路,判斷一個(gè)字符串是否為數(shù)字是Java開發(fā)中很常見的業(yè)務(wù)需求,實(shí)現(xiàn)這個(gè)判斷有很多種方式,需要的朋友可以參考下2023-08-08