使用 GreenDao,我设法将我的数据库置于我拥有一个没有密钥的实体的状态。
我的问题是如何清除/删除该实体?我没有在 AbstractDao 中看到可以让我删除另一个列名的函数。
使用 GreenDao,我设法将我的数据库置于我拥有一个没有密钥的实体的状态。
我的问题是如何清除/删除该实体?我没有在 AbstractDao 中看到可以让我删除另一个列名的函数。
主键本身是唯一的,而不是 null ,即使我明确提到它 (not null().primaryKey()) ,它也应该可以完美地工作。我想指出,是我做错了还是greenDAO有问题。greenDAO 是否有任何消息可以解决即将发布的版本中的问题。
我没有太多的声誉,否则我会在评论中问它。
您可以编写一个原始 SQL 查询来删除该行并使用您可以从可读的 DaoSession 中获取的 SQLiteDatabase 执行它。
DELETE FROM YourTable WHERE someColumn=?
如果你想避免拼写错误,你可以使用 greendao 的 tableinformation:
String query = "DELETE FROM " + YourDao.TABLENAME +
" WHERE " + YourDao.Properties.SomeColumn.columnName + "=?";
了解更多信息:
根据您创建架构的方式,存在一些陷阱:
如果你创建了主键,AUTOINCREMENT
而NOT NULL
greendao将无法正确插入主键!
分配自动递增的主键时,主键总是会0
在向表中插入第二行时导致约束冲突。
notNull().primaryKey().autoincrement()
因此,如果您不想处理 greendao-sourcecode,则不应使用.
我对 greendao-core 进行了一些小改动,以便能够使用上面的语句,但是如果只使用primaryKey().autoincrement()
.