Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/374.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Android Studio房间类型转换器的问题_Java_Android - Fatal编程技术网

Java Android Studio房间类型转换器的问题

Java Android Studio房间类型转换器的问题,java,android,Java,Android,由于某些原因,我在Android Studio中遇到了类型转换器的问题。我在其他帖子中尝试过各种解决方案,但仍然会遇到这个错误。当我尝试使用字符串的Arraylist而不是成分时,typeconverter确实可以工作 错误:无法确定如何将此字段保存到数据库中。可以考虑为它添加一个类型转换器。< /P> 新的答案是将配料重命名为配料解决了问题??所以…也许要注意这些类名,并遵循ClassNamesStartUpperCase的Java约定 旧答案: 我认为,您可能需要为您的配料创建一个单独的“实

由于某些原因,我在Android Studio中遇到了类型转换器的问题。我在其他帖子中尝试过各种解决方案,但仍然会遇到这个错误。当我尝试使用字符串的Arraylist而不是成分时,typeconverter确实可以工作

错误:无法确定如何将此字段保存到数据库中。可以考虑为它添加一个类型转换器。< /P> 新的答案是将配料重命名为配料解决了问题??所以…也许要注意这些类名,并遵循ClassNamesStartUpperCase的Java约定

旧答案:

我认为,您可能需要为您的配料创建一个单独的“实体”,就像recipesDB一样

然后,配料将@ForeignKey设置回recipesDB

最后,您可以添加一个POJO,使recipesDB和ArrayList都具有

我这里没有样品,但我在网上看到了很多


我认为问题在于你的“转换器”不知道如何转换“成分”。虽然它知道如何转换列表,但它不是一回事

因此,问题的原因是由于我当前文件夹目录范围之外存在重复的配料类。通过将类成分更改为成分,它一定已经消除了房间的混淆。

您是否使用相应的注释@TypeConverters{YourDataConverter.class}将其添加到DB中?@MartinMarconcini是的,我这样做了。您的类型转换器似乎没有被使用,您可以粘贴房间DB抽象类吗?另外,请将配料重命名为配料,以使Java/Kotlin更易于阅读;按照惯例,类型应该以大写字母开头,并遵循CamelCase:@MartinMarconcini,所以我认为重构解决了这个问题。我目前无法完全测试它,但我认为它起了作用。非常感谢。从配料->配料重构我的类名解决了这个问题。无法解释原因,但你关于修改我的文件名的建议起了作用。那么也许我错了!:很高兴听到它起作用了。我将为未来的读者更新答案。请@JDoe将答案标记为正确答案,好吗?
@Entity(tableName = "Recipes")
    public class recipesDB {
        @PrimaryKey
        @NonNull
        @ColumnInfo(name = "recipeID")
        private int id;

    //Foreign Key to be used from Ingredients
    @ColumnInfo(name = "name")
    private String name;

    @ColumnInfo(name = "url")
    private String url;

    @ColumnInfo(name = "readyInMinutes")
    private int readyInMinutes;

//Issue Here
@ColumnInfo(name = "ingredients")
private ArrayList<ingredient> ingredients;
public class DataConverter{


    @TypeConverter
    public static ArrayList<ingredient> toIngredient(String s){
        if(s == null){
            return null;
        }

        Gson gson = new Gson();
        Type listType = new TypeToken<ArrayList<ingredient>>(){}.getType();
        ArrayList<ingredient> ingredients = gson.fromJson(s, listType);
        return ingredients;
    }

    @TypeConverter
    public static String getIngredients(ArrayList<ingredient> ingredients){
        if(ingredients == null){
            return null;
        }

        Gson gson = new Gson();
        Type type = new TypeToken<ArrayList<ingredient>>() {}.getType();
        String json = gson.toJson(ingredients);
        return json;
    }
@Database(entities = {recipesDB.class}, version = 1, exportSchema = false)
@TypeConverters({DataConverter.class})
public abstract class AppDatabase extends RoomDatabase {
    private static AppDatabase INSTANCE;
    public abstract recipesDAO recipesdao();
    //public abstract pantryDAO pantrydao();
    public static AppDatabase getInMemoryDatabase(Context context) {
        if (INSTANCE == null) {
            INSTANCE = Room.inMemoryDatabaseBuilder(context.getApplicationContext(), AppDatabase.class).build();
        }
        return INSTANCE;
    }
    public static void destroyInstance(){INSTANCE = null;}
}