在写DAO层时,觉得从Cursor里一个一个的取出字段值再装到VO(值对象)里太麻烦了,就写了一个工具类,用到了反射,可以把查询记录的值装到对应的VO里,也可以生成该VO的List。
使用时需要注意:
考虑到AndroID的性能问题,VO没有使用Setter和Getter,而是直接用public的属性。
表中的字段名需要和VO的属性名一样,要是不一样就得在查询的sql中使用字段别名让字段别名和VO属性名一样。
下面是高清有码:
view plain importjava.lang.reflect.Constructor; importjava.lang.reflect.FIEld; importjava.util.HashMap; importjava.util.linkedList; importjava.util.List; importjava.util.Map; importandroID.database.Cursor; importandroID.database.sqlite.sqliteDatabase; /** *通过SQL语句查询出结果并封闭到VO里 * *@authordengzer@gmail.com *@version创建时间:2011-10-28下午05:27:39 */ publicclassHappysql{ *通过SQL语句获得对应的VO。注意:Cursor的字段名或者别名一定要和VO的成员名一样 *@paramdb *@paramsql *@paramclazz *@return @SuppressWarnings("rawtypes") staticObjectsql2VO(sqliteDatabasedb,Stringsql,Classclazz){ Cursorc=db.rawquery(sql,null); returncursor2VO(c,clazz); } *@paramselectionArgs *@paramclazz *@return */ @SuppressWarnings("rawtypes") String[]selectionArgs,Classclazz){ *通过SQL语句获得对应的VO的List。注意:Cursor的字段名或者别名一定要和VO的成员名一样 staticListsql2VOList(sqliteDatabasedb,153); background-color:inherit; Font-weight:bold">returncursor2VOList(c,0); background-color:inherit">*通过Cursor转换成对应的VO。注意:Cursor里的字段名(可用别名)必须要和VO的属性名一致 *@paramc @SuppressWarnings({"rawtypes","unused"}) privatestaticObjectcursor2VO(Cursorc,Classclazz){ if(c==null){ returnnull; } Objectobj; inti=1; try{ c.movetoNext(); obj=setValues2FIElds(c,clazz); returnobj; }catch(Exceptione){ System.out.println(e); System.out.println("ERROR@:cursor2VO"); finally{ c.close(); *通过Cursor转换成对应的VO集合。注意:Cursor里的字段名(可用别名)必须要和VO的属性名一致 "unchecked"}) staticListcursor2VOList(Cursorc,255); color:inherit; line-height:21px"> ListList=newlinkedList(); Objectobj; while(c.movetoNext()){ List.add(obj); returnList; }catch(Exceptione){ e.printstacktrace(); System.out.println("ERROR@:cursor2VOList"); null; finally{ c.close(); /** *把值设置进类属性里 * *@paramcolumnnames *@paramfIElds *@paramc *@paramobj *@throwsException staticObjectsetValues2FIElds(Cursorc,Classclazz) throwsException{ String[]columnnames=c.getColumnnames();//字段数组 Objectobj=clazz.newInstance(); FIEld[]fIElds=clazz.getFIElds(); for(FIEld_fIEld:fIElds){ Class<?extendsObject>typeClass=_fIEld.getType();//属性类型 for(intj=0;j<columnnames.length;j++){ Stringcolumnname=columnnames[j]; typeClass=getBasicclass(typeClass); booleanisBasicType=isBasicType(typeClass); if(isBasicType){ if(columnname.equalsIgnoreCase(_fIEld.getname())){//是基本类型 String_str=c.getString(c.getColumnIndex(columnname)); if(_str==break; _str=_str==null?"":_str; Constructor<?extendsObject>cons=typeClass .getConstructor(String.class); Objectattribute=cons.newInstance(_str); _fIEld.setAccessible(true); _fIEld.set(obj,attribute); else{ Objectobj2=setValues2FIElds(c,typeClass);//递归 _fIEld.set(obj,obj2); break; *判断是不是基本类型 *@paramtypeClass staticbooleanisBasicType(ClasstypeClass){ if(typeClass.equals(Integer.class)||typeClass.equals(Long.class) ||typeClass.equals(float.class) ||typeClass.equals(Double. ||typeClass.equals(Boolean. ||typeClass.equals(Byte. ||typeClass.equals(Short. ||typeClass.equals(String.class)){ true; else{ false; *获得包装类 *@paramtypeClass @SuppressWarnings("all") staticClass<?extendsObject>getBasicclass(ClasstypeClass){ Class_class=basicMap.get(typeClass); if(_class==null) _class=typeClass; return_class; staticMap<Class,Class>basicMap=newHashMap<Class,Class>(); static{ basicMap.put(int.class,Integer.class); basicMap.put(long.float.double.boolean.byte.short. }
调用例子:
获得单个VO:
Stringsql="select*fromtb_info_revIEwwhereinfo_ID=" +info_ID; return(Info_re)Happysql.sql2VO(db,sql,92); line-height:21px"> Info_re.class);
获得List:
Stringsql="select*fromtb_infom,tb_sub2fwherem.send_state=1andrevIEw_state=0andm.info_ID=f.info_ID"; List<Info>infos=Happysql .sql2VOList(db,Info.class); 带变参获得List:
以上是内存溢出为你收集整理的SQLite的工具类 ---- 通过反射把Cursor封装到VO对象全部内容,希望文章能够帮你解决SQLite的工具类 ---- 通过反射把Cursor封装到VO对象所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)