Ami*_*tel 5 java database sqlite android android-database
我有一个 VideoList 对象,我想使用房间库保存它,但是当我尝试将 @Embedded 与 public List list = null; 一起使用时 它给我以下错误: 错误:(23, 24) 错误:无法弄清楚如何将此字段保存到数据库中。您可以考虑为其添加类型转换器。
VideoList类如下。
@Entity
public class VideoList {
@PrimaryKey
public String id;
public String title;
public String viewType;
public Integer sortingOrder = null;
public String componentSlug;
public String endPoint = null;
@Embedded
public List<Video> list = null;
public boolean hidden = false; }
Any suggestions?
Run Code Online (Sandbox Code Playgroud)
我认为 Converter 是这种嵌套列表对象中最好的解决方案。
public class Converter {
public static String strSeparator = "__,__";
@TypeConverter
public static String convertListToString(List<Video> video) {
Video[] videoArray = new Video[video.size()];
for (int i = 0; i <= video.size()-1; i++) {
videoArray[i] = video.get(i);
}
String str = "";
Gson gson = new Gson();
for (int i = 0; i < videoArray.length; i++) {
String jsonString = gson.toJson(videoArray[i]);
str = str + jsonString;
if (i < videoArray.length - 1) {
str = str + strSeparator;
}
}
return str;
}
@TypeConverter
public static List<Video> convertStringToList(String videoString) {
String[] videoArray = videoString.split(strSeparator);
List<Video> videos = new ArrayList<Video>();
Gson gson = new Gson();
for (int i=0;i<videoArray.length-1;i++){
videos.add(gson.fromJson(videoArray[i] , Video.class));
}
return videos;
}
Run Code Online (Sandbox Code Playgroud)
}
| 归档时间: |
|
| 查看次数: |
6830 次 |
| 最近记录: |