1. 如果主键标记时没有添加autoincrement , 那么就是传的id重复了, 传的时候获取最新id然后++id即可, 这里不讨论

@Id(autoincrement = true)


2. 我明明标了autoincrement , 按理不用传id的, 也确实没传, 还爆not unique的话, 就是踩坑了

GreenDao的主键必须设置成包装类 Long , 大写L

原因就在这里 :  如果主键设置为包装类Long类型, 那么在生成的Dao类中会有一个判断非null才插入
private Long _id;

@Override
protected final void bindValues(SQLiteStatement stmt, IdCache entity) {
    stmt.clearBindings();

    Long _id = entity.get_id();
    if (_id != null) {
        stmt.bindLong(1, _id);
    }
    stmt.bindString(2, entity.getUser());
}

但是如果写的是 long, 就无脑写进去了, 也就是说即使不传值,也会insert _id = 0, 于是报异常;
@Id(autoincrement = true)
private long _id;

@Override
protected final void bindValues(DatabaseStatement stmt, IdCache entity) {
    stmt.clearBindings();
    stmt.bindLong(1, entity.get_id());
    stmt.bindString(2, entity.getUser());
}




更多推荐

GreenDao insert 解决 PRIMARY KEY must be unique (code 19)