有时候,我们的实体类中会有一些属性,但是数据库中没有对应的类型,这个时候我们就需要自定义转换器进行类型转换。很常见的处理就是Date类型一般如果精度要求不高的话我们会转换为Long类型进行存储,读取的的时候再讲其转换为Date类型。那么如果我们想要让它直接以时间字符串存储呢,这个也好办,GreenDao为我们提供了自定义类型转换的支持。
首先,我们需要实现PropertyConverter接口,实现里面的两个方法convertToEntityProperty和convertToDatabaseValue,该接口需要两个泛型参数,第一个参数是实体类中的类型,第二个参数是数据库中存储的类型。现在假设我们需要将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