Unique constraint failed room database android

不打扰是莪最后的温柔 提交于 2020-02-14 19:12:51

问题


I'm facing a problem with Room database, when trying to use insert method that I declared in Dao Class to write a data into database this error shows up:

Unique constraint failed

Any idea way?

Dao Class

@Dao
public interface TaskDao {

    @Query("SELECT * FROM task")
    List<Task> getall();

    @Insert
    void insert(Task task);

    @Delete
    void delete(Task task);
}

AppDatabase Class

@Database(entities = {Task.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {
    public abstract TaskDao mTaskDao();
}

Model Class

@Entity
public class Task {

    @PrimaryKey
    private int uid;

    @ColumnInfo(name = "task_name")
    private String mName;

    @ColumnInfo(name = "task_box")
    private Integer mBox;

    @ColumnInfo(name = "is_done")
    private Integer mIsDone;
}

回答1:


I figure it out, that error because there is no unique value in data (in primaryKey) so I make it auto generated,

Model Class

@Entity
public class Task {
    @PrimaryKey(autoGenerate = true)
    private int uid;
    ...
}



回答2:


AppDatabase Class

@Database(entities = {Task.class}, version = 1, exportSchema = false)
public abstract class AppDatabase extends RoomDatabase {
    public abstract TaskDao mTaskDao();
}

Model Class

@Entity
public class Task {

    @PrimaryKey(autoGenerate = true)
    private int uid;

    @ColumnInfo(name = "task_name")
    private String mName;

    @ColumnInfo(name = "task_box")
    private Integer mBox;

    @ColumnInfo(name = "is_done")
    private Integer mIsDone;
}


来源:https://stackoverflow.com/questions/50558275/unique-constraint-failed-room-database-android

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!