首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >唯一约束失败房间数据库android

唯一约束失败房间数据库android
EN

Stack Overflow用户
提问于 2018-05-28 10:11:29
回答 2查看 7.4K关注 0票数 10

我遇到了一个Room数据库的问题,当我尝试使用我在Dao类中声明的insert方法将数据写入数据库时,出现了这个错误:

唯一约束失败

有什么好办法吗?

Dao类

代码语言:javascript
复制
@Dao
public interface TaskDao {

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

    @Insert
    void insert(Task task);

    @Delete
    void delete(Task task);
}

AppDatabase类

代码语言:javascript
复制
@Database(entities = {Task.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {
    public abstract TaskDao mTaskDao();
}

模型类

代码语言:javascript
复制
@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;
}
EN

回答 2

Stack Overflow用户

发布于 2018-05-28 10:15:48

我找出了这个错误,因为数据中没有唯一值(在primaryKey中),所以我让它自动生成,

模型类

代码语言:javascript
复制
@Entity
public class Task {
    @PrimaryKey(autoGenerate = true)
    private int uid;
    ...
}
票数 9
EN

Stack Overflow用户

发布于 2018-07-06 18:14:29

AppDatabase类

代码语言:javascript
复制
@Database(entities = {Task.class}, version = 1, exportSchema = false)
public abstract class AppDatabase extends RoomDatabase {
    public abstract TaskDao mTaskDao();
}

模型类

代码语言:javascript
复制
@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;
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50558275

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档