我不确定房间有什么大惊小怪的,因为我发现它很烂。几乎没有任何效果像预期的那样。对于我的问题,我想测试一下它们拥有的类型转换器(到目前为止令人失望)。为了测试它,我从网上看到的一个示例制作了一个简单的类。我敢肯定这是愚蠢的,甚至与代码无关,但是无论如何我都会在这里尝试一下。到目前为止,我有:
@Entity
public class User {
@PrimaryKey
private int id;
private String name;
@TypeConverters(Converters.class)
List<String> pets = new ArrayList<>();
public User() { }
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List<String> getPets() {
return pets;
}
public void setPets(List<String> pets) {
this.pets = pets;
}
}
然后转换器:
public class Converters {
@TypeConverter
public static ArrayList<String> fromString(String value) {
Type listType = new TypeToken<ArrayList<String>>() {}.getType();
return new Gson().fromJson(value, listType);
}
@TypeConverter
public static String fromArrayList(ArrayList<String> list) {
Gson gson = new Gson();
String json = gson.toJson(list);
return json;
}
}
一个简单的道:
@Dao
public interface UserDao {
@Insert(onConflict = REPLACE)
void insertUser(User user);
@Query("SELECT * FROM User")
List<User> getUsers();
}
最后是数据库:
@Database(entities = { User.class,}, version = 1, exportSchema = false)
@TypeConverters({Converters.class})
public abstract class RoomDb extends RoomDatabase {
public abstract UserDao userDao();
}
我仍然得到“无法弄清楚如何将该字段保存到数据库中。您可以考虑为其添加类型转换器”。没有任何详细信息说明转换器为何不工作或发生了什么。为了避免麻烦,我已经尝试过像其他解决方案所建议的那样,在自己的字段上使用@Converters。
到目前为止,Room让我对复杂的问题感到失望,当您的模型相当复杂时,我发现Realm和ObjectBox更加一致。
随您的见解自由参加斗争。
答案 0 :(得分:1)
class Convertes {
@TypeConverter
fun fromSource(source: Source) :String{
return source.name
}
@TypeConverter
fun tvSource(name: String): Source {
return Source( name,name)
}
}
答案 1 :(得分:0)
而不是Converters类中的ArrayList。尝试列表。您的实体正在使用List作为其声明的类。可能有问题。
这是上述克诺索斯提出的解决方案。我最终用ArrayList进行了测试并开始工作。