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封装类

2022-02-21 18:43:42

Spring封装多线程

2018-01-30 18:49:16

前端JavascriptCSS

2009-12-25 15:28:48

ADO类

2012-07-11 15:54:59

canvas

2023-09-18 07:46:28

2012-12-26 09:31:44

C#Winform

2024-04-01 13:05:13

C++接口类开发

2009-08-19 15:44:09

ObjectARX .

2021-05-13 07:58:05

JDBC接口PreparedSta

2024-01-29 16:47:44

函数封装开发

2014-07-31 18:23:41

Process

2020-12-31 09:04:54

Java类的设计类的封装

2009-06-19 13:37:53

Spring JDBC

2010-07-06 16:19:02

协议封装

2010-07-13 09:08:27

Widget开发

2009-07-15 15:47:12

JDBC DAO

2010-04-14 15:22:53

Oracle JDBC

2021-11-09 07:26:14

CssMaterialUI React
点赞
收藏

51CTO技术栈公众号