成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JDBC的封裝類構建

開發 后端
在JAVA中JDBC的訪問是比較麻煩的,為此可以使用封裝的方法構建一個封裝性較好的JDBC工具類,提高編程的可復用性。

在JAVA中JDBC的訪問是比較麻煩的,為此可以使用封裝的方法構建一個封裝性較好的JDBC工具類,提高編程的可復用性。

具體的想法是:可以生成一個類封裝JDBC的connection和statement的構建,使用Property配置文件來保存JDBC訪問的路徑以及驅動,這樣可以有較好的可維護性,再使用反射特性構建一個DataUtil類封裝JDBC獲取的結果集,并把其顯示出來。

1.首先新建一個jdbc.property文件存放jdbc的相關屬性

  1. jdbc.driver=com.mysql.jdbc.Driver  
  2. jdbc.url=jdbc:mysql://localhost:3306/user  
  3. jdbc.user=root  
  4. jdbc.pass=123456 

通過PropertyUtil類可以獲得jdbc的屬性

  1. package jdbc;  
  2.  
  3. import java.io.IOException;  
  4. import java.io.InputStream;  
  5. import java.util.Properties;  
  6.  
  7. /**  
  8.  * 屬性工具類  
  9.  */ 
  10. public class PropertiesUtil {  
  11.     //屬性列表  
  12.     private static Properties properties = new Properties();  
  13.     //配置文件的路徑  
  14.     private static String CONFIG = "/cfg/jdbc.properties";  
  15.     //讀取資源文件, 設置輸入流  
  16.     private static InputStream is = PropertiesUtil.class.getResourceAsStream(CONFIG);  
  17.     //數據庫驅動  
  18.     public static String JDBC_DRIVER;  
  19.     //jdbc連接url  
  20.     public static String JDBC_URL;  
  21.     //數據庫用戶名  
  22.     public static String JDBC_USER;  
  23.     //數據庫密碼  
  24.     public static String JDBC_PASS;  
  25.     static {  
  26.         try {  
  27.             //加載輸入流  
  28.             properties.load(is);  
  29.             //獲得配置的各個屬性  
  30.             JDBC_DRIVER = properties.getProperty("jdbc.driver");  
  31.             JDBC_URL = properties.getProperty("jdbc.url");  
  32.             JDBC_USER = properties.getProperty("jdbc.user");  
  33.             JDBC_PASS = properties.getProperty("jdbc.pass");  
  34.         } catch (IOException e) {  
  35.             e.printStackTrace();  
  36.         }  
  37.     }  

2.建立JDBCExecutor類來封裝JDBC的數據源獲取工作,其中通過單例模式獲取數據庫的連接

  1. package jdbc;  
  2.  
  3. import java.sql.Connection;  
  4. import java.sql.DriverManager;  
  5. import java.sql.ResultSet;  
  6. import java.sql.Statement;  
  7.  
  8. public class JDBCExecutor{  
  9.     //獲得驅動  
  10.     private static String DRIVER = PropertiesUtil.JDBC_DRIVER;  
  11.     //獲得url  
  12.     private static String URL = PropertiesUtil.JDBC_URL;  
  13.     //獲得連接數據庫的用戶名  
  14.     private static String USER = PropertiesUtil.JDBC_USER;  
  15.     //獲得連接數據庫的密碼  
  16.     private static String PASS = PropertiesUtil.JDBC_PASS;  
  17.     //連接對象  
  18.     private Connection connection;  
  19.     //維護一個本類型的對象  
  20.     private static JDBCExecutor jdbcExecutor;  
  21.     //Statement對象,可以執行SQL語句并返回結果  
  22.     private Statement stmt;  
  23.       
  24.     //私有構造器  
  25.     private JDBCExecutor() {  
  26.         try {  
  27.             //初始化JDBC驅動并讓驅動加載到jvm中  
  28.             Class.forName(DRIVER);  
  29.             //創建數據庫連接  
  30.             connection = DriverManager.getConnection(URL, USER, PASS);  
  31.             //創建Statement對象  
  32.             stmt = connection.createStatement();  
  33.         } catch (Exception e) {  
  34.             throw new JDBCException(e.getMessage());  
  35.         }  
  36.     }  
  37.       
  38.     //提供一個靜態方法返回本類的實例  
  39.     public static JDBCExecutor getJDBCExecutor() {  
  40.         //如果本類所維護jdbcExecutor屬性為空,則調用私有的構造器獲得實例  
  41.         if (jdbcExecutor == null) {  
  42.             jdbcExecutor = new JDBCExecutor();  
  43.         }  
  44.         return jdbcExecutor;  
  45.     }  
  46.       
  47.     /*  
  48.      * 執行一句查詢的sql  
  49.      */ 
  50.     public ResultSet executeQuery(String sql) {  
  51.         try {  
  52.             //利用Statement對象執行參數的sql  
  53.             ResultSet result = stmt.executeQuery(sql);  
  54.             return result;  
  55.         } catch (Exception e) {  
  56.             throw new QueryException(e.getMessage());  
  57.         }  
  58.     }  
  59.       
  60.     //執行單句INSERT、UPDATE 或 DELETE 語句, 如果執行INSERT時, 返回主鍵  
  61.     public int executeUpdate(String sql) {  
  62.         int result = -1;  
  63.         try {  
  64.             //執行SQL語句  
  65.             stmt.executeUpdate(sql);  
  66.             //獲得主鍵  
  67.             ResultSet rs = stmt.getGeneratedKeys();  
  68.             while(rs.next()) {  
  69.                 //返回最后一個主鍵  
  70.                 result = rs.getInt(1);  
  71.             }  
  72.             rs.close();  
  73.             return result;  
  74.         } catch (Exception e) {  
  75.             throw new QueryException(e.getMessage());  
  76.         }  
  77.     }  

3.為了將JDBC查詢操作的數據獲取,封裝數據獲取的類

  1. package jdbc;  
  2.  
  3.  
  4. import java.lang.reflect.Field;  
  5. import java.lang.reflect.Method;  
  6. import java.sql.ResultSet;  
  7. import java.util.ArrayList;  
  8. import java.util.Collection;  
  9.  
  10. import vo.User;  
  11. import dao.impl.UserDAOImpl;  
  12.  
  13.  
  14. /**  
  15.  * 數據轉換工具類  
  16.  */ 
  17. public class DataUtil {  
  18.  static UserDAOImpl us=new UserDAOImpl();  
  19.  //將rs中的值封裝成一個集合  
  20.  public static Collection getDatas(Collection result, ResultSet rs, Class clazz) {  
  21.   try {  
  22.    while (rs.next()) {  
  23.     //創建類的實例  
  24.     Object vo = clazz.newInstance();  
  25.     //獲取本對象的屬性  
  26.     Field[] fields = clazz.getDeclaredFields();  
  27.     //獲取父類的屬性  
  28. //    Field[] superFields = clazz.getSuperclass().getDeclaredFields();  
  29. //    //父類的屬性和自己的屬性相加  
  30. //    Field[] allFields = addFields(superFields, fields);  
  31.     //遍歷所有的屬性  
  32.     for (Field field : fields) {  
  33.      //獲得setter方法的方法名  
  34.      String setterMethodName = getSetterMethodName(field.getName());  
  35.      //獲得setter方法  
  36.      Method setterMethod = clazz.getMethod(setterMethodName, field.getType());  
  37.      invokeMethod(rs, field, vo, setterMethod);  
  38.     }  
  39.     result.add(vo);  
  40.    }  
  41.    rs.close();  
  42.   } catch (Exception e) {  
  43.    e.printStackTrace();  
  44.    throw new DataException(e.getMessage());  
  45.   }  
  46.   return result;  
  47.  }  
  48.    
  49.  //執行一個方法, 從ResultSet中獲取一個字段的數據, 調用vo的setter方法  
  50.  private static void invokeMethod(ResultSet rs, Field field, Object vo,   
  51.    Method setterMethod) {  
  52.   try {  
  53.    //當使用ResultSet獲取某個字段的時候, 如果沒有該字段, 會出現SQLException, 在這里忽略該異常  
  54.    String value = rs.getString(field.getName());  
  55.    //從ResultSet中獲取與該對象屬性名一致的字段, 并執行setter方法  
  56.    setterMethod.invoke(vo, value);  
  57.   } catch (Exception e) {  
  58.    //忽略異常  
  59.   }  
  60.  }  
  61.    
  62.  //根據屬性名獲得setter方法的方法名  
  63.  private static String getSetterMethodName(String fieldName) {  
  64.   String begin = fieldName.substring(01).toUpperCase();  
  65.   String end = fieldName.substring(1, fieldName.length());  
  66.   String methodName = "set" + begin + end;  
  67.   return methodName;  
  68.  }  
  69.    
  70.  //測試方法  
  71.  public static void main(String[] args) {  
  72.   JDBCExecutor executor = JDBCExecutor.getJDBCExecutor();  
  73.   us.AddUser(new User("111",12,"333"));  
  74. //  ResultSet rs = executor.executeQuery("select * from user");  
  75. //  Collection<User> result = DataUtil.getDatas(new ArrayList<User>(), rs,   
  76. //    User.class);  
  77. //  for (User user : result) {  
  78. //   System.out.println(user.getName());  
  79. //  }  
  80.  }  

通過上面Main方法中的調用,可以看出能夠很輕易的操縱JDBC連接了。

原文鏈接:http://blog.csdn.net/rommel1/article/details/7294501

【編輯推薦】

  1. Java并發編程之同步互斥問題
  2. Java中String.format的用法
  3. 郵件功能開發:JavaMail
  4. 6個提高Java開發者效率的工具
  5. 關于讀寫鎖算法的Java實現及思考
責任編輯:林師授 來源: rommel1的博客
相關推薦

2009-12-07 15:34:18

PHP類的封裝

2009-08-19 09:36:03

ADO封裝類

2018-01-30 18:49:16

前端JavascriptCSS

2022-02-21 18:43:42

Spring封裝多線程

2009-12-25 15:28:48

ADO類

2012-07-11 15:54:59

canvas

2021-05-13 07:58:05

JDBC接口PreparedSta

2012-12-26 09:31:44

C#Winform

2024-04-01 13:05:13

C++接口類開發

2023-09-18 07:46:28

2009-06-19 13:37:53

Spring JDBC

2024-01-29 16:47:44

函數封裝開發

2024-05-27 00:00:00

C# 類參數數據

2009-08-19 15:44:09

ObjectARX .

2014-07-31 18:23:41

Process

2020-12-31 09:04:54

Java類的設計類的封裝

2010-04-14 15:22:53

Oracle JDBC

2009-07-15 15:47:12

JDBC DAO

2010-07-06 16:19:02

協議封裝

2010-07-13 09:08:27

Widget開發
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 三级视频在线观看 | 国产成人福利视频 | 久久6| 操操操日日日 | 国产精品国产成人国产三级 | 草b视频| 91亚洲精品久久久电影 | 日本视频在线 | 亚洲午夜在线 | 亚洲欧美在线一区 | 欧美日韩精品一区二区三区四区 | 欧美成人免费在线 | 国产精品久久久av | 成人福利在线观看 | 国产资源网 | 亚洲欧美综合精品久久成人 | 久久久久无码国产精品一区 | 一呦二呦三呦国产精品 | 欧美精品免费观看二区 | 成人黄在线观看 | 欧美综合久久 | 日韩中文字幕 | 久久成人免费观看 | 看片91| 久久久91精品国产一区二区三区 | 午夜精品久久 | 一本色道久久综合亚洲精品高清 | 射欧美 | 国产剧情久久 | 国产精品免费一区二区三区四区 | 成人激情视频免费观看 | 国产亚洲精品久久久久久豆腐 | 日韩和的一区二在线 | 一级a性色生活片久久毛片波多野 | 国产欧美精品一区二区色综合朱莉 | 成人免费久久 | 久久精品视频99 | 韩日av片 | 精品国产三级 | 国产成年人视频 | 欧美色性 |