首先创建数据库表的实体类
GreenDao 默认不⽀持集合对象Beans.所以需要转换为其他类型保存到数据库。
给字段添加@Convert注解,意味着,把该字段的数据转换为其他类型进⾏保存到数据库。
converter 转换器
columnType 数据库中保存的字段类型
@Entity(nameInDb = "ym_test") public class ReportCacheDaoBean { @Id @Property(nameInDb = "ID") private String ID; @Property(nameInDb = "ISSUE") private String ISSUE; @Property(nameInDb = "ADRESS") private String ADRESS; @Convert(columnType = String.class, converter = PhotoSrcBeanConverter.class) private List<PhotoSrcBean> srcBeans;
}
然后要实现PropertyConverter接口,重写里面的两个方法
convertToEntityProperty()//转换为对象属性
convertToDatabaseValue()//转换为数据库属性
public class PhotoSrcBeanConverter implements PropertyConverter<List<PhotoSrcBean>,String> {
/**
* 转换成对象属性
* @param databaseValue
* @return
*/
@Override
public List<PhotoSrcBean> convertToEntityProperty(String databaseValue) {
if (databaseValue==null){
return null;
}
PhotoSrcBean[] array = new Gson().fromJson(databaseValue, PhotoSrcBean[].class);
List<PhotoSrcBean> list_str = Arrays.asList(array);
List<PhotoSrcBean> srcBeanList= new ArrayList<>();
if (list_str.size() > 0) {
srcBeanList.addAll(list_str);
}
return srcBeanList;
}
/**
* 转换成数据库属性
* @param arrays
* @return
*/
@Override
public String convertToDatabaseValue(List<PhotoSrcBean> arrays) {
if (arrays == null) {
return null;
} else {
return GsonUtils.toJson(arrays);//转换成String类型
}
}
}
完活!下课。