Java反射机制在DAO层的应用实例
来源:互联网 发布:店铺淘宝客怎么做 编辑:程序博客网 时间:2024/05/22 17:19
Java反射机制在DAO层的应用实例
(注:本文实例经典,特此转载)
基本原理;保存数据时,把需要保存的对象的属性值全部取出来再拼凑sql语句
查询时,将查询到的数据全部包装成一个java对象。
游戏规则:俗话说的好,无规矩不成方圆,特别是程序来说,它只能做有规则的事情,没有规则的它干不了,好,那就
先定规则
1)数据库的每一个表对象一个pojo类,表中的每一个字段对应pojo类的中的一个属性。
并且pojo类的名字和表的名字相同,属性名和字段名相同,大小写没有关系,因为数据库一般不区分大小写
2)为pojo类中的每一个属性添加标准的set和get方法。
有了游戏规则,那么开始游戏吧。
1、首先数据库的有一个表,假设数据库名称为:blogsystem,里面的一个表名userinfo。如图:
2、创建对应的pojo类:
package cn.netjava.pojo; public class UserInfo {private int id;private String name;private String pwd;private int age; @Overridepublic String toString() { return "UserInfo [id=" + id + ", name=" + name + ", pwd=" + pwd + ", age=" + age + "]";}public int getId() { return id;}public void setId(int id) { this.id = id;}public String getName() { return name;}public void setName(String name) { this.name = name;}public String getPwd() { return pwd;}public void setPwd(String pwd) { this.pwd = pwd;}public int getAge() { return age;}public void setAge(int age) { this.age = age;} }
3、编写获得数据库连接的工厂类:
package cn.netjava.factory; import java.sql.Connection;import java.sql.DriverManager; public class Connect2DBFactory { public static Connection getDBConnection() { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql://localhost:3306/blogsystem"; String user = "root"; String password = "netjava"; conn = DriverManager.getConnection(url, user, password); } catch (Exception e) { e.printStackTrace(); } return conn; }}
4、编写操作数据库的dao类:
package cn.netjava.session; import java.lang.reflect.Field;import java.lang.reflect.Method;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.ArrayList;import java.util.List; import cn.netjava.factory.Connect2DBFactory;import cn.netjava.pojo.UserInfo; public class NetJavaSession { /** * 解析出保存对象的sql语句 * * @param object * :需要保存的对象 * @return:保存对象的sql语句 */ public static String getSaveObjectSql(Object object) { // 定义一个sql字符串 String sql = "insert into "; // 得到对象的类 Class c = object.getClass(); // 得到对象中所有的方法 Method[] methods = c.getMethods(); // 得到对象中所有的属性 Field[] fields = c.getFields(); // 得到对象类的名字 String cName = c.getName(); // 从类的名字中解析出表名 String tableName = cName.substring(cName.lastIndexOf(".") + 1, cName.length()); sql += tableName + "("; List<String> mList = new ArrayList<String>(); List vList = new ArrayList(); for (Method method : methods) { String mName = method.getName(); if (mName.startsWith("get") && !mName.startsWith("getClass")) { String fieldName = mName.substring(3, mName.length()); mList.add(fieldName); System.out.println("字段名字----->" + fieldName); try { Object value = method.invoke(object, null); System.out.println("执行方法返回的值:" + value); if (value instanceof String) { vList.add("\"" + value + "\""); System.out.println("字段值------>" + value); } else { vList.add(value); } } catch (Exception e) { e.printStackTrace(); } } } for (int i = 0; i < mList.size(); i++) { if (i < mList.size() - 1) { sql += mList.get(i) + ","; } else { sql += mList.get(i) + ") values("; } } for (int i = 0; i < vList.size(); i++) { if (i < vList.size() - 1) { sql += vList.get(i) + ","; } else { sql += vList.get(i) + ")"; } } return sql; } public static List getDatasFromDB(String tableName, int Id) { return null; } /** * 将对象保存到数据库中 * * @param object * :需要保存的对象 * @return:方法执行的结果;1:表示成功,0:表示失败 */ public int saveObject(Object object) { Connection con = Connect2DBFactory.getDBConnection(); String sql = getSaveObjectSql(object); try { // Statement statement=(Statement) con.createStatement(); PreparedStatement psmt = con.prepareStatement(sql); psmt.executeUpdate(); return 1; } catch (SQLException e) { e.printStackTrace(); return 0; } } /** * 从数据库中取得对象 * * @param arg0 * :对象所属的类 * @param id * :对象的id * @return:需要查找的对象 */ public Object getObject(String className, int Id) { // 得到表名字 String tableName = className.substring(className.lastIndexOf(".") + 1, className.length()); // 根据类名来创建Class对象 Class c = null; try { c = Class.forName(className); } catch (ClassNotFoundException e1) { e1.printStackTrace(); } // 拼凑查询sql语句 String sql = "select * from " + tableName + " where Id=" + Id; System.out.println("查找sql语句:" + sql); // 获得数据库链接 Connection con = Connect2DBFactory.getDBConnection(); // 创建类的实例 Object obj = null; try { Statement stm = con.createStatement(); // 得到执行查寻语句返回的结果集 ResultSet set = stm.executeQuery(sql); // 得到对象的方法数组 Method[] methods = c.getMethods(); // 遍历结果集 while (set.next()) { obj = c.newInstance(); // 遍历对象的方法 for (Method method : methods) { String methodName = method.getName(); // 如果对象的方法以set开头 if (methodName.startsWith("set")) { // 根据方法名字得到数据表格中字段的名字 String columnName = methodName.substring(3, methodName.length()); // 得到方法的参数类型 Class[] parmts = method.getParameterTypes(); if (parmts[0] == String.class) { // 如果参数为String类型,则从结果集中按照列名取得对应的值,并且执行改set方法 method.invoke(obj, set.getString(columnName)); } if (parmts[0] == int.class) { method.invoke(obj, set.getInt(columnName)); } } } } } catch (Exception e) { e.printStackTrace(); } return obj; }}
5、测试效果
package cn.netjava.tester; import cn.netjava.pojo.UserInfo;import cn.netjava.session.NetJavaSession; public class Tester { public static void main(String args[]) { //获得NetJavaSession对象 NetJavaSession session = new NetJavaSession(); //创建一个UserInfo对象 UserInfo user = new UserInfo(); //设置对象的属性 user.setId(6988); user.setAge(44); user.setPwd("pwd"); user.setName("champion"); //将对象保存到数据库中 String sql = session.getSaveObjectSql(user); System.out.println("保存对象的sql语句:" + sql); //查找对象 UserInfo userInfo = (UserInfo) session.getObject( "cn.netjava.pojo.UserInfo", 6988); System.out.println("获取到的信息:" + userInfo); }}
6、输出结果
0 0
- Java反射机制在DAO层的应用实例
- Java反射机制在dao类的应用
- Android基于Java反射机制的简单ORM-Dao层
- Java 反射机制的应用实例
- 反射机制的应用实例
- java反射机制的两个具体应用实例
- JAVA反射机制的应用实例(将任一va…
- JAVA反射机制深入学习(二)实例演示JAVA反射机制的应用
- 反射机制简化Dao层开发
- JAVA反射机制web中的应用实例
- JAVA反射机制与实例应用
- Java反射机制浅析图+应用实例
- JAVA反射机制的应用
- java反射机制的应用
- java反射机制的应用
- java 反射机制的应用
- java反射机制的应用
- 在项目的实际开发中,dao层java泛型的的应用(ssh)
- 递归函数时间复杂度分析
- 在JSP页面获取当前项目名称的方法
- SPServices介绍之六:上传附件
- 创建临时表
- 获取手机联系人
- Java反射机制在DAO层的应用实例
- C语言--结构体大小
- 【Linux】tcpdump 命令详解
- 一组基于SVG矢量图库和jQuery/GSAP的精美图标动画
- cmd ren命令 重命名文件(夹)
- 【干货分享】移动营销宝典--入门篇
- 2014 年最火的 21 款JavaScript 框架
- ubuntu命令查询版本和内核版本
- 记录通过mybatis处理大批量oracle数据