自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JDBC的封裝類構(gòu)建

開(kāi)發(fā) 后端
在JAVA中JDBC的訪問(wèn)是比較麻煩的,為此可以使用封裝的方法構(gòu)建一個(gè)封裝性較好的JDBC工具類,提高編程的可復(fù)用性。

在JAVA中JDBC的訪問(wèn)是比較麻煩的,為此可以使用封裝的方法構(gòu)建一個(gè)封裝性較好的JDBC工具類,提高編程的可復(fù)用性。

具體的想法是:可以生成一個(gè)類封裝JDBC的connection和statement的構(gòu)建,使用Property配置文件來(lái)保存JDBC訪問(wèn)的路徑以及驅(qū)動(dòng),這樣可以有較好的可維護(hù)性,再使用反射特性構(gòu)建一個(gè)DataUtil類封裝JDBC獲取的結(jié)果集,并把其顯示出來(lái)。

1.首先新建一個(gè)jdbc.property文件存放jdbc的相關(guān)屬性

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

通過(guò)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.     //讀取資源文件, 設(shè)置輸入流  
  16.     private static InputStream is = PropertiesUtil.class.getResourceAsStream(CONFIG);  
  17.     //數(shù)據(jù)庫(kù)驅(qū)動(dòng)  
  18.     public static String JDBC_DRIVER;  
  19.     //jdbc連接url  
  20.     public static String JDBC_URL;  
  21.     //數(shù)據(jù)庫(kù)用戶名  
  22.     public static String JDBC_USER;  
  23.     //數(shù)據(jù)庫(kù)密碼  
  24.     public static String JDBC_PASS;  
  25.     static {  
  26.         try {  
  27.             //加載輸入流  
  28.             properties.load(is);  
  29.             //獲得配置的各個(gè)屬性  
  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類來(lái)封裝JDBC的數(shù)據(jù)源獲取工作,其中通過(guò)單例模式獲取數(shù)據(jù)庫(kù)的連接

  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.     //獲得驅(qū)動(dòng)  
  10.     private static String DRIVER = PropertiesUtil.JDBC_DRIVER;  
  11.     //獲得url  
  12.     private static String URL = PropertiesUtil.JDBC_URL;  
  13.     //獲得連接數(shù)據(jù)庫(kù)的用戶名  
  14.     private static String USER = PropertiesUtil.JDBC_USER;  
  15.     //獲得連接數(shù)據(jù)庫(kù)的密碼  
  16.     private static String PASS = PropertiesUtil.JDBC_PASS;  
  17.     //連接對(duì)象  
  18.     private Connection connection;  
  19.     //維護(hù)一個(gè)本類型的對(duì)象  
  20.     private static JDBCExecutor jdbcExecutor;  
  21.     //Statement對(duì)象,可以執(zhí)行SQL語(yǔ)句并返回結(jié)果  
  22.     private Statement stmt;  
  23.       
  24.     //私有構(gòu)造器  
  25.     private JDBCExecutor() {  
  26.         try {  
  27.             //初始化JDBC驅(qū)動(dòng)并讓驅(qū)動(dòng)加載到j(luò)vm中  
  28.             Class.forName(DRIVER);  
  29.             //創(chuàng)建數(shù)據(jù)庫(kù)連接  
  30.             connection = DriverManager.getConnection(URL, USER, PASS);  
  31.             //創(chuàng)建Statement對(duì)象  
  32.             stmt = connection.createStatement();  
  33.         } catch (Exception e) {  
  34.             throw new JDBCException(e.getMessage());  
  35.         }  
  36.     }  
  37.       
  38.     //提供一個(gè)靜態(tài)方法返回本類的實(shí)例  
  39.     public static JDBCExecutor getJDBCExecutor() {  
  40.         //如果本類所維護(hù)jdbcExecutor屬性為空,則調(diào)用私有的構(gòu)造器獲得實(shí)例  
  41.         if (jdbcExecutor == null) {  
  42.             jdbcExecutor = new JDBCExecutor();  
  43.         }  
  44.         return jdbcExecutor;  
  45.     }  
  46.       
  47.     /*  
  48.      * 執(zhí)行一句查詢的sql  
  49.      */ 
  50.     public ResultSet executeQuery(String sql) {  
  51.         try {  
  52.             //利用Statement對(duì)象執(zhí)行參數(shù)的sql  
  53.             ResultSet result = stmt.executeQuery(sql);  
  54.             return result;  
  55.         } catch (Exception e) {  
  56.             throw new QueryException(e.getMessage());  
  57.         }  
  58.     }  
  59.       
  60.     //執(zhí)行單句INSERT、UPDATE 或 DELETE 語(yǔ)句, 如果執(zhí)行INSERT時(shí), 返回主鍵  
  61.     public int executeUpdate(String sql) {  
  62.         int result = -1;  
  63.         try {  
  64.             //執(zhí)行SQL語(yǔ)句  
  65.             stmt.executeUpdate(sql);  
  66.             //獲得主鍵  
  67.             ResultSet rs = stmt.getGeneratedKeys();  
  68.             while(rs.next()) {  
  69.                 //返回最后一個(gè)主鍵  
  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查詢操作的數(shù)據(jù)獲取,封裝數(shù)據(jù)獲取的類

  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.  * 數(shù)據(jù)轉(zhuǎn)換工具類  
  16.  */ 
  17. public class DataUtil {  
  18.  static UserDAOImpl us=new UserDAOImpl();  
  19.  //將rs中的值封裝成一個(gè)集合  
  20.  public static Collection getDatas(Collection result, ResultSet rs, Class clazz) {  
  21.   try {  
  22.    while (rs.next()) {  
  23.     //創(chuàng)建類的實(shí)例  
  24.     Object vo = clazz.newInstance();  
  25.     //獲取本對(duì)象的屬性  
  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.  //執(zhí)行一個(gè)方法, 從ResultSet中獲取一個(gè)字段的數(shù)據(jù), 調(diào)用vo的setter方法  
  50.  private static void invokeMethod(ResultSet rs, Field field, Object vo,   
  51.    Method setterMethod) {  
  52.   try {  
  53.    //當(dāng)使用ResultSet獲取某個(gè)字段的時(shí)候, 如果沒(méi)有該字段, 會(huì)出現(xiàn)SQLException, 在這里忽略該異常  
  54.    String value = rs.getString(field.getName());  
  55.    //從ResultSet中獲取與該對(duì)象屬性名一致的字段, 并執(zhí)行setter方法  
  56.    setterMethod.invoke(vo, value);  
  57.   } catch (Exception e) {  
  58.    //忽略異常  
  59.   }  
  60.  }  
  61.    
  62.  //根據(jù)屬性名獲得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.  //測(cè)試方法  
  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.  }  

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

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

【編輯推薦】

  1. Java并發(fā)編程之同步互斥問(wèn)題
  2. Java中String.format的用法
  3. 郵件功能開(kāi)發(fā):JavaMail
  4. 6個(gè)提高Java開(kāi)發(fā)者效率的工具
  5. 關(guān)于讀寫(xiě)鎖算法的Java實(shí)現(xiàn)及思考
責(zé)任編輯:林師授 來(lái)源: rommel1的博客
相關(guān)推薦

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

2023-09-18 07:46:28

2024-04-01 13:05:13

C++接口類開(kāi)發(fā)

2012-12-26 09:31:44

C#Winform

2024-01-29 16:47:44

函數(shù)封裝開(kāi)發(fā)

2014-07-31 18:23:41

Process

2009-08-19 15:44:09

ObjectARX .

2009-06-19 13:37:53

Spring JDBC

2020-12-31 09:04:54

Java類的設(shè)計(jì)類的封裝

2024-05-27 00:00:00

C# 類參數(shù)數(shù)據(jù)

2010-04-14 15:22:53

Oracle JDBC

2009-07-15 15:47:12

JDBC DAO

2010-07-06 16:19:02

協(xié)議封裝

2010-07-13 09:08:27

Widget開(kāi)發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)