码迷,mamicode.com
首页 > 移动开发 > 详细

android中利用java反射原理将对象添加到sqlit数据库的万能方法

时间:2015-03-31 18:05:29      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:android   数据库   sqlit   java反射机制   万能添加对象到数据库   

利用java的反射机制,我们可以得到对象里的方法列表,参数列表以及对应的值,那么我们就可以利用这些做一个万能的插入数据库的方法。


以下方法中表名要和数据库名一致。

 protected void insert(Object ob){
ContentValues initialValues = new ContentValues(); 
Class c = ob.getClass();
String className = c.getName();
String tableName = className.substring(className.toString().lastIndexOf(".")+1);
String deviceName = "";
System.out.println("tableName:"+tableName);
Field[] fields= c.getDeclaredFields();
try {
for(Field f:fields){
f.setAccessible(true);  
String str =f.toString().substring(f.toString().lastIndexOf(".")+1);
Object obj = f.get(ob);
if(str.equals("deviceName"));
if(obj!=null&&!obj.toString().equals("0")){
initialValues.put(str, obj+"");
}
// System.out.println("params:"+str+" value:"+f.get(ob).toString());
}
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
long ss = db.insert(tableName, null, initialValues);

}

增删该查应该都可以利用发射原理做,这里只做了添加处理。


android中利用java反射原理将对象添加到sqlit数据库的万能方法

标签:android   数据库   sqlit   java反射机制   万能添加对象到数据库   

原文地址:http://blog.csdn.net/yeyuehei/article/details/44782281

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!