Android ORM系列之GreenDao自定义类型转换器与代码混淆配置

来源:互联网 发布:mac强制卸载ltu软件 编辑:程序博客网 时间:2024/06/04 19:31

有时候,我们的实体类中会有一些属性,但是数据库中没有对应的类型,这个时候我们就需要自定义转换器进行类型转换。很常见的处理就是Date类型一般如果精度要求不高的话我们会转换为Long类型进行存储,读取的的时候再讲其转换为Date类型。那么如果我们想要让它直接以时间字符串存储呢,这个也好办,GreenDao为我们提供了自定义类型转换的支持。

首先,我们需要实现PropertyConverter接口,实现里面的两个方法convertToEntityPropertyconvertToDatabaseValue,该接口需要两个泛型参数,第一个参数是实体类中的类型,第二个参数是数据库中存储的类型。现在假设我们需要将Date转换为String进行存储,那么接口的实现应该是这样的。

public class DateStringConverter implements PropertyConverter<Date,String> {    @Override    public Date convertToEntityProperty(String databaseValue) {        return null;    }    @Override    public String convertToDatabaseValue(Date entityProperty) {        return bull;    }}

接下来我们进行转换

public class DateStringConverter implements PropertyConverter<Date,String> {    private static final String DEFAULT_FORMAT="yyyy-MM-dd HH:mm:ss";    @Override    public Date convertToEntityProperty(String databaseValue) {        return convert2Date(databaseValue,DEFAULT_FORMAT);    }    @Override    public String convertToDatabaseValue(Date entityProperty) {        return convert2String(entityProperty,DEFAULT_FORMAT);    }    public static String convert2String(Date date,String format){        String currentDate=null;        try {            SimpleDateFormat formatter=new SimpleDateFormat(format);            currentDate=formatter.format(date);        }catch (Exception e){            e.printStackTrace();        }        return currentDate;    }    public static Date convert2Date(String day, String format) {        if (day == null || format == null)            return null;        SimpleDateFormat formatter = new SimpleDateFormat(format);        try {            Date dt = formatter.parse(day);            return dt;        } catch (ParseException e) {            e.printStackTrace();        }        return null;    }}

之后生成实体类

Entity type = schema.addEntity("Demo");type.addStringProperty("test").customType("java.util.Date","cn.edu.zafu.greendao.db.converter.DateStringConverter");

addProperty的时候是对应的数据库中的类型,这里我们存储为字符串,所以是addStringProperty,然后通过customType函数指定实体类中的类型,这里是java.util.Date,接着就是我们的类型转换器的全类名。接着试试往数据库中插入一条数据,我们会发现他直接以字符串存储了,如图所示

这里写图片描述

最后附带一下混淆配置,给需要混淆的项目加入以下语句

-keepclassmembers class * extends de.greenrobot.dao.AbstractDao {    public static java.lang.String TABLENAME;}-keep class **$Properties
4 0