设为首页 收藏本站
查看: 1304|回复: 0

[经验分享] [转]SQLite的工具类 ---- 通过反射把Cursor封装到VO对象

[复制链接]

尚未签到

发表于 2016-12-1 11:42:10 | 显示全部楼层 |阅读模式
  在写DAO层时,觉得从Cursor里一个一个的取出字段值再装到VO(值对象)里太麻烦了,就写了一个工具类,用到了反射,可以把查询记录的值装到对应的VO里,也可以生成该VO的List。
  使用时需要注意:


  考虑到Android的性能问题,VO没有使用Setter和Getter,而是直接用public的属性。

  表中的字段名需要和VO的属性名一样,要是不一样就得在查询的SQL中使用字段别名让字段别名和VO属性名一样。

  下面是实现代码:



import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
/**
* 通过SQL语句查询出结果并封闭到VO里
*
*
*/
public class HappySQL {
/**
* 通过SQL语句获得对应的VO。注意:Cursor的字段名或者别名一定要和VO的成员名一样
*
* @param db
* @param sql
* @param clazz
* @return
*/
@SuppressWarnings("rawtypes")
public static Object sql2VO(SQLiteDatabase db, String sql, Class clazz) {
Cursor c = db.rawQuery(sql, null);
return cursor2VO(c, clazz);
}
/**
* 通过SQL语句获得对应的VO。注意:Cursor的字段名或者别名一定要和VO的成员名一样
*
* @param db
* @param sql
* @param selectionArgs
* @param clazz
* @return
*/
@SuppressWarnings("rawtypes")
public static Object sql2VO(SQLiteDatabase db, String sql,
String[] selectionArgs, Class clazz) {
Cursor c = db.rawQuery(sql, selectionArgs);
return cursor2VO(c, clazz);
}
/**
* 通过SQL语句获得对应的VO的List。注意:Cursor的字段名或者别名一定要和VO的成员名一样
*
* @param db
* @param sql
* @param clazz
* @return
*/
@SuppressWarnings("rawtypes")
public static List sql2VOList(SQLiteDatabase db, String sql, Class clazz) {
Cursor c = db.rawQuery(sql, null);
return cursor2VOList(c, clazz);
}
/**
* 通过SQL语句获得对应的VO的List。注意:Cursor的字段名或者别名一定要和VO的成员名一样
*
* @param db
* @param sql
* @param selectionArgs
* @param clazz
* @return
*/
@SuppressWarnings("rawtypes")
public static List sql2VOList(SQLiteDatabase db, String sql,
String[] selectionArgs, Class clazz) {
Cursor c = db.rawQuery(sql, selectionArgs);
return cursor2VOList(c, clazz);
}
/**
* 通过Cursor转换成对应的VO。注意:Cursor里的字段名(可用别名)必须要和VO的属性名一致
*
* @param c
* @param clazz
* @return
*/
@SuppressWarnings({ "rawtypes", "unused" })
private static Object cursor2VO(Cursor c, Class clazz) {
if (c == null) {
return null;
}
Object obj;
int i = 1;
try {
c.moveToNext();
obj = setValues2Fields(c, clazz);
return obj;
} catch (Exception e) {
System.out.println(e);
System.out.println("ERROR @:cursor2VO");
return null;
} finally {
c.close();
}
}
/**
* 通过Cursor转换成对应的VO集合。注意:Cursor里的字段名(可用别名)必须要和VO的属性名一致
*
* @param c
* @param clazz
* @return
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
private static List cursor2VOList(Cursor c, Class clazz) {
if (c == null) {
return null;
}
List list = new LinkedList();
Object obj;
try {
while (c.moveToNext()) {
obj = setValues2Fields(c, clazz);
list.add(obj);
}
return list;
} catch (Exception e) {
e.printStackTrace();
System.out.println("ERROR @:cursor2VOList");
return null;
} finally {
c.close();
}
}
/**
* 把值设置进类属性里
*
* @param columnNames
* @param fields
* @param c
* @param obj
* @throws Exception
*/
@SuppressWarnings("rawtypes")
private static Object setValues2Fields(Cursor c, Class clazz)
throws Exception {
String[] columnNames = c.getColumnNames();// 字段数组
Object obj = clazz.newInstance();
Field[] fields = clazz.getFields();
for (Field _field : fields) {
Class<? extends Object> typeClass = _field.getType();// 属性类型
for (int j = 0; j < columnNames.length; j++) {
String columnName = columnNames[j];
typeClass = getBasicClass(typeClass);
boolean isBasicType = isBasicType(typeClass);
if (isBasicType) {
if (columnName.equalsIgnoreCase(_field.getName())) {// 是基本类型
String _str = c.getString(c.getColumnIndex(columnName));
if (_str == null) {
break;
}
_str = _str == null ? "" : _str;
Constructor<? extends Object> cons = typeClass
.getConstructor(String.class);
Object attribute = cons.newInstance(_str);
_field.setAccessible(true);
_field.set(obj, attribute);
break;
}
} else {
Object obj2 = setValues2Fields(c, typeClass);// 递归
_field.set(obj, obj2);
break;
}
}
}
return obj;
}
/**
* 判断是不是基本类型
*
* @param typeClass
* @return
*/
@SuppressWarnings("rawtypes")
private static boolean isBasicType(Class typeClass) {
if (typeClass.equals(Integer.class) || typeClass.equals(Long.class)
|| typeClass.equals(Float.class)
|| typeClass.equals(Double.class)
|| typeClass.equals(Boolean.class)
|| typeClass.equals(Byte.class)
|| typeClass.equals(Short.class)
|| typeClass.equals(String.class)) {
return true;
} else {
return false;
}
}
/**
* 获得包装类
*
* @param typeClass
* @return
*/
@SuppressWarnings("all")
public static Class<? extends Object> getBasicClass(Class typeClass) {
Class _class = basicMap.get(typeClass);
if (_class == null)
_class = typeClass;
return _class;
}
@SuppressWarnings("rawtypes")
private static Map<Class, Class> basicMap = new HashMap<Class, Class>();
static {
basicMap.put(int.class, Integer.class);
basicMap.put(long.class, Long.class);
basicMap.put(float.class, Float.class);
basicMap.put(double.class, Double.class);
basicMap.put(boolean.class, Boolean.class);
basicMap.put(byte.class, Byte.class);
basicMap.put(short.class, Short.class);
}
}
  调用例子:


  获得单个VO:


String sql = "select * from tb_info_review where info_id = "
+ info_id;
return (Info_re) HappySQL.sql2VO(db, sql,
Info_re.class);
  获得List:


String sql = "select * from tb_info m, tb_sub2 f where m.send_state = 1
and review_state = 0 and m.info_id = f.info_id";
List<Info> infos = HappySQL.sql2VOList(db, sql, Info.class);

  带变参获得List:


String sql = "select * from tb_info m,tb_ttf f where m.info_id = ? and m.info_id = f.info_id";
return (SbMan) HappySQL.sql2VO(db, sql, new String[] { info_id + "" }, SbMan.class);
  转自:http://blog.csdn.net/oo8_8oo/article/details/7003162

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-308206-1-1.html 上篇帖子: Android笔记——Day5 *SQLite基本用法 *Broadcast广播机制 *WiFi基础 下篇帖子: android对sqlite数据库操作(创建 增 删 改 查)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表