亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

基于JDBC訪問MySql公共方法實例解析

瀏覽:21日期:2023-02-06 11:07:25

本來項目都是用到例如Hibernate這些工具的,可是因為現在項目要求現在又丫的回到基于JDK的解決方案了。

這個方法很簡單,但是對于數據的連接使用連接池,連接池也是直接初始化的。

package com;import java.sql.*;import java.util.*;import org.apache.commons.dbcp.BasicDataSource;/** * @說明 數據庫連接管理 * @author cuisuqiang */public class ConnectionManager {/** * @說明 執行一條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[]>(); // 總數據Object[] objects = null; // 每行數據try {conn = ConnectionManager.getConn(); // 得到鏈接if(null != conn){psta = conn.prepareStatement(sql);resultSet = psta.executeQuery(); // 執行查詢,返回結果接集合int count = resultSet.getMetaData().getColumnCount(); // 一共有多少列數據// 循環行while (resultSet.next()) {objects = new Object[count];// 數據集索引從 1 開始,而數組存放時是從 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(); // 組建數據源對象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);}/** * 從數據源中取得數據庫連接 */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 + 'tt'); }else if(o instanceof Long){ Long s = (Long) o; System.out.print('浮點值:' + s + 'tt'); }else if(o instanceof Integer){ Integer s = (Integer) o; System.out.print('整形值:' + s + 'tt'); }else{ System.out.print('未知型:' + o + 'tt'); } } System.out.println(); } } catch (Exception e) { e.printStackTrace(); } } }

我返回的是一個List集合,里面包含了一個Object數組。調用者在收到這個返回集合后可以根據實際情況進行解析,公共方法只是執行SQL,然后得到數據連接進行數據訪問。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JDBC
相關文章:
主站蜘蛛池模板: 黄色视屏日本 | 中文字幕在线高清 | 九九精品视频一区在线 | 国产精品一级毛片不收费 | 久久精品中文字幕首页 | 免费香蕉视频 | 99re在线播放 | 国产精品久久婷婷六月丁香 | 在线一区| 免费视频不卡一区二区三区 | 四虎澳门永久8848在线影院 | 成年人免费观看网站 | 欧美影视一区 | 91爱啪啪 | 国产综合精品 | 嫩草成人永久免费观看 | 欧美亚洲日本一区二区三区浪人 | 最近的免费中文字幕视频 | 精品国产丝袜自在线拍国 | 亚洲一区高清 | 九九久久99综合一区二区 | 一级大毛片 | 天天色一色 | 中国一级片免费看 | 手机视频在线观看 | 伊人骚 | 黄色毛片视频在线观看 | 在线观看亚洲 | 国产区香蕉精品系列在线观看不卡 | 欧美变态口味重另类日韩毛片 | 日本内谢69xxxx免费播放 | 美女国产精品福利视频 | 1314亚洲人成网站在线观看 | 欧美成人伊人久久综合网 | 特黄特色大片免费视频播放 | 国产欧美日韩在线播放 | 亚洲国产综合专区在线播一一 | 国产高清国内精品福利色噜噜 | 日韩欧美一级 | 国产亚洲欧美日韩综合综合二区 | 北条麻妃一区二区三区 |