我最近将我的数据库更新为FTS3,因为我请求了搜索功能。
我的FTS3表:
db.execSQL("CREATE VIRTUAL TABLE " + TABLE_FTS + " USING fts3(" + COL_ID + ", " + COL_KEY_NAME + ", "
+ COL_KEY_WEBURL + " , " + COL_KEY_MAINURL + ", " + COL_KEY_CODEC + " " + ");");我总是使用ContextMenu从我的列表视图中输入删除项。我用了这样的方法:
AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo)item.getMenuInfo();
delete(info.id);
updateList();
public void delete(long id) {
int numDeleted = database.delete("stations" , "_ID = ?", new String[] { Long.toString(id) } );
Log.d(TAG, "delete(): id=" + id + " -> " + numDeleted);
}
public void updateList() {
data.requery();
dataSource.notifyDataSetChanged();
}这个方法,info.id没有给我这个职位,所以我把它改成了info.position。位置是对的,但delet不起作用。好的,我尝试了一个简单的删除,而不是通过Android方法。
database.execSQL("DELETE FROM " + DatabaseHelper.TABLE_FTS + " WHERE " + DatabaseHelper.COL_ID + "='" + id + "'");别再工作了。在FTS3中,似乎不再存在具有自动递增数的列吗?我想,我可以使用rowid,但它不像预期的那样工作。如果我删除了我的第一个条目,下面的条目就会被删除。
我怎样才能让它像以前一样工作呢?编辑:找到了现在修复..。
发布于 2012-02-07 23:13:06
找到fix了。不要按ID删除,现在按名称删除。
发布于 2012-09-22 20:10:13
我想问题来自于
_ID = ?_ID是整数了吗?被字符串替换。你的第二种不工作方式也是如此。
https://stackoverflow.com/questions/9099737
复制相似问题