作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 GreenDao,我以某种方式设法将我的数据库置于一个没有 key 的实体的状态。
我的问题是如何清除/删除该实体?我在 AbstractDao 中没有看到可以让我删除另一个列名的函数。
最佳答案
您可以编写原始 SQL 查询来删除该行,并使用可从可读 DaoSession 中获取的 SQLiteDatabase 执行它。
DELETE FROM YourTable WHERE someColumn=?
如果你想避免拼写错误,你可以使用 greendao 的表格信息:
String query = "DELETE FROM " + YourDao.TABLENAME +
" WHERE " + YourDao.Properties.SomeColumn.columnName + "=?";
<小时/>
了解更多信息:
根据您创建架构的方式,存在一些陷阱:
如果您使用 AUTOINCRMENT
和 NOT NULL
创建主键 greendao 将无法正确插入主键!
不再分配自动增量主键,主键将始终为 0
,从而导致在表中插入第二行时发生约束冲突。
因此,如果您不想处理 greendao 源代码,则不应使用 notNull().primaryKey().autoincrement()
。
我对 greendao-core 做了一些小的更改,以便能够使用上面的语句,但是如果仅使用 primaryKey().autoincrement()
,一切都应该运行良好。
关于greendao DaoException 实体没有键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19839817/
使用 GreenDao,我以某种方式设法将我的数据库置于一个没有 key 的实体的状态。 我的问题是如何清除/删除该实体?我在 AbstractDao 中没有看到可以让我删除另一个列名的函数。 最佳答
我是一名优秀的程序员,十分优秀!