gpt4 book ai didi

greendao DaoException 实体没有键

转载 作者:行者123 更新时间:2023-12-01 16:23:34 25 4
gpt4 key购买 nike

使用 GreenDao,我以某种方式设法将我的数据库置于一个没有 key 的实体的状态。

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

最佳答案

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

DELETE FROM YourTable WHERE someColumn=?

如果你想避免拼写错误,你可以使用 greendao 的表格信息:

String query = "DELETE FROM " + YourDao.TABLENAME +
" WHERE " + YourDao.Properties.SomeColumn.columnName + "=?";
<小时/>

了解更多信息:

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

如果您使用 AUTOINCRMENTNOT NULL 创建主键 greendao 将无法正确插入主键!

不再分配自动增量主键,主键将始终为 0,从而导致在表中插入第二行时发生约束冲突。

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

我对 greendao-core 做了一些小的更改,以便能够使用上面的语句,但是如果仅使用 primaryKey().autoincrement(),一切都应该运行良好。

关于greendao DaoException 实体没有键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19839817/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com