java反射技术的应用

如何用java反射技术将sql操作与面向对象编程关联起来

请看一例


public class SqlUtil extends BaseApplogic {

public List excuteQuery(String sql, Object[] paras, Object voo)
throws AppException {
DBPersistenceManager dbpm = this.getFnmsDBPM();
List list=new ArrayList();
try {
DataSet ds = (DataSet) dbpm.executeQuery(sql, paras);

DataSetMetaData dsmd = ds.getDataSetMetaData();

Field[] fd = voo.getClass().getDeclaredFields();
String className = voo.getClass().getName();
int size = fd.length;
Method md[]=new Method[size];
//构造method[]
for (int i = 0; i < size; i++) {
Attribute attr=dsmd.getAttribute(fd[i].getName().toUpperCase());
if (null != attr) {
Field f = voo.getClass().getDeclaredField(fd[i].getName());
String type = f.getType().getName();
Class[] types=getTypes(type);
String methodName=getSetterName(fd[i].getName());
md[i] = voo.getClass().getMethod(
methodName,types);
}
}

while(ds.next()){
Object o = Class.forName(className).newInstance();
for (int i = 0; i < size; i++) {
if(null!=md[i]){
//调用
Attribute attr=dsmd.getAttribute(fd[i].getName().toUpperCase());
if (null==attr) continue;
Object[] pa=new Object[]{ds.getString(attr.getAttrName())};
md[i].invoke(o,pa);
}
}
list.add(o);
}
} catch (DrmException drme) {
this.handleException(drme);
} catch (Exception e) {
this.handleException(e);// 新增加的异常处理
} finally {
if (dbpm != null) {
dbpm.close();
}
}
return list;

}

//由属性调用set方法
public static String getSetterName(String propName) {
return "set" + propName.substring(0, 1).toUpperCase()
+ propName.substring(1, propName.length());

}

// 取类型
public static Class[] getTypes(String type) {
if (type.equals("java.lang.String")) {
return new Class[] { String.class };
} else if (type.equals("int")) {
return new Class[] { Integer.TYPE };
} else if (type.equals("long")) {
return new Class[] { Long.TYPE };
} else if (type.equals("float")) {
return new Class[] { Float.TYPE };
} else {
System.out.println("no such type!");
return null;
}

}
}

[@more@]

其中excuteQuery方法传入三个参数,第一个是要查询的sql语句,第二个是参数数组,第三个是要返回的对象类型。

返回值是一个list,list中的每个对象都是你传入的对象类型。

经过这样一种包装,将sql与对象自然的封装起来,不用每个查询都查出来以后,再resultset.next(),再getString(),然后再setXxx();

当然,这只是元数据与java对象反射技术利用的冰山一角。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/11419868/viewspace-1002535/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/11419868/viewspace-1002535/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在向学生讲解Class.forName()方法的使用时,有时需要扩展讲解为什么这样书写的原理,于是,扩展讲解Java反射技术可以查看被监视类的方法(构造方法和普通方法)、公有属性的功能,以达到封闭功能的效果。该例子使用MyEclipse 5.5完成demo示例。其中,com.jb.arklis.app.DemoApplication类利用反射技术可以观察任何非静态类(比如java.lang.String, javax.swing.JFrame等类和自定义的类,比如com.jb.arklis.dao.BaseDAO)的普通方法、构造方法以公有属性,是一个非常有实用意义的显示类。 该示例没有使用泛型技术,所以不是很完美。不过只要你稍微修改一下,就可作为自己工程中比较好的封装工具类使用! 下载解压之后,使用MyEclipse 5.5导入,打开该工程,找到DemoApplication类,然后点击run菜单-->找到(x)Arguments,然后在Program arguments中输入: com.jb.arklis.dao.BaseDAO, 然后点击run按钮,如果一切正常,那么你会看到使用反射在DemoApplication类中呼叫了BaseDAO的returnTestValue(String name)方法。 我的代码注释非常详细,相信当你看完之后,一般来说,如果不是新手(非常菜的人),那么你应该学会使用反射技术来实现封装的动作了--也就是说,你的技术有了一个非常大的提高--如果你看完之后,参见该示例中另外的JDBC代码,然后能够实现对JDBC进一步的封装,使JDBC连接的使用步骤更简单的话! OK,Good luck!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值