国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

基于JDBC訪問(wèn)MySql公共方法實(shí)例解析

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

本來(lái)項(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;/** * @說(shuō)明 數(shù)據(jù)庫(kù)連接管理 * @author cuisuqiang */public class ConnectionManager {/** * @說(shuō)明 執(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 開(kāi)始,而數(shù)組存放時(shí)是從 0 開(kāi)始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ù)庫(kù)連接 */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 + 'tt'); }else if(o instanceof Long){ Long s = (Long) o; System.out.print('浮點(diǎn)值:' + 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(); } } }

我返回的是一個(gè)List集合,里面包含了一個(gè)Object數(shù)組。調(diào)用者在收到這個(gè)返回集合后可以根據(jù)實(shí)際情況進(jìn)行解析,公共方法只是執(zhí)行SQL,然后得到數(shù)據(jù)連接進(jìn)行數(shù)據(jù)訪問(wèn)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JDBC
相關(guān)文章:
主站蜘蛛池模板: 成人精品一区二区激情 | 成人深夜福利在线播放不卡 | 久久亚洲天堂 | 国产乱码精品一区二区三区卡 | 一区二区三区伦理 | 精品一久久香蕉国产二月 | 久久久国产一区二区三区 | 久草资源网站 | 综合 欧美 亚洲日本 | 国产高清在线看免费视频观 | 国产成人精品福利网站在线观看 | 亚洲国产精品免费在线观看 | 欧美zoofilia杂交videos | 国产精品日产三级在线观看 | 日韩亚洲国产综合久久久 | 亚洲精品久久久久久久久久久网站 | 久久99精品久久久久久h | 成年人网站免费视频 | 99亚洲精品 | a级毛片免费观看在线播放 a级毛片免费看 | 日本一线a视频免费观看 | 亚欧在线视频 | 中文日韩字幕 | 三级黄色网址 | 真人一级毛片 | 好叼操这里只有精品 | 99爱精品视频| 美女一级毛片免费看看 | 怡红院成人在线 | 美国一级毛片在线 | 欧美成人观看视频在线 | 国产精品手机在线 | 男女很舒服爽视频免费 | 香蕉依依精品视频在线播放 | 免费日本视频 | 日韩欧美一级毛片精品6 | 国内精品1区1区3区4区 | 日本韩国三级在线 | 国产欧美一区二区三区免费看 | 一色屋色费精品视频在线观看 | 亚洲一区免费在线 |