4

使用 GreenDao,我设法将我的数据库置于我拥有一个没有密钥的实体的状态。

我的问题是如何清除/删除该实体?我没有在 AbstractDao 中看到可以让我删除另一个列名的函数。

4

2 回答 2

0

主键本身是唯一的,而不是 null ,即使我明确提到它 (not null().primaryKey()) ,它也应该可以完美地工作。我想指出,是我做错了还是greenDAO有问题。greenDAO 是否有任何消息可以解决即将发布的版本中的问题。

我没有太多的声誉,否则我会在评论中问它。

于 2014-10-28T11:31:18.033 回答
0

您可以编写一个原始 SQL 查询来删除该行并使用您可以从可读的 DaoSession 中获取的 SQLiteDatabase 执行它。

DELETE FROM YourTable WHERE someColumn=?

如果你想避免拼写错误,你可以使用 greendao 的 tableinformation:

String query = "DELETE FROM " + YourDao.TABLENAME +
               " WHERE " + YourDao.Properties.SomeColumn.columnName + "=?";

了解更多信息:

根据您创建架构的方式,存在一些陷阱:

如果你创建了主键,AUTOINCREMENTNOT NULLgreendao将无法正确插入主键!

分配自动递增的主键时,主键总是会0在向表中插入第二行时导致约束冲突。

notNull().primaryKey().autoincrement()因此,如果您不想处理 greendao-sourcecode,则不应使用.

我对 greendao-core 进行了一些小改动,以便能够使用上面的语句,但是如果只使用primaryKey().autoincrement().

于 2013-11-08T15:06:38.330 回答