12

我正在学习 Android,但遇到了一个涉及调用自定义内容提供程序的问题。我一直在使用指导书中的示例,虽然它描述了如何创建自定义提供程序,但没有明确的示例如何调用其中的特定方法。我正在专门研究如何从自定义内容提供程序中删除单个记录。

以下是自定义内容提供程序 ( EarthquakeProvider.java) 的代码:

@Override


public int delete(Uri uri, String where, String[] whereArgs) {
int count;

switch (uriMatcher.match(uri)) {
  case QUAKES:
    count = earthquakeDB.delete(EARTHQUAKE_TABLE, where, whereArgs);
    break;

  case QUAKE_ID:
    String segment = uri.getPathSegments().get(1);
    count = earthquakeDB.delete(EARTHQUAKE_TABLE, KEY_ID + "="
                                + segment
                                + (!TextUtils.isEmpty(where) ? " AND (" 
                                + where + ')' : ""), whereArgs);
    break;

  default: throw new IllegalArgumentException("Unsupported URI: " + uri);
}

getContext().getContentResolver().notifyChange(uri, null);
return count;


 }

我试图从主要活动中调用 delete 方法来删​​除单个条目,而不是整个数据库。我想对OnLongClickListener在主活动的数组列表视图中显示的所选记录使用 about。

到目前为止,这是我在此方法的主要活动中提出的:

earthquakeListView.setOnItemLongClickListener(new OnItemLongClickListener() {

    @Override
    public boolean onItemLongClick(AdapterView _av, View _v, int _index,
            long arg3) {
        ContentResolver cr = getContentResolver();
        cr.delete(earthquakeProvider.CONTENT_URI, null, null); 

        return false;
    }

我知道上面的代码不起作用,但这与我目前的理解一样接近。

对此的任何帮助将不胜感激。

4

1 回答 1

26
cr.delete(earthquakeProvider.CONTENT_URI, null, null);

这是你的问题。首先,一些背景:

内容 URI:(来源

content://authority/path/##

最后的数字是可选的。如果存在,URI 引用数据库中的特定行,其中 row._id=(数字)。如果不存在,它将引用整个表。

delete() 调用接受一个 URI、一个 where 子句和一组被替换的字符串。示​​例:假设您有一个人员数据库。

cr.delete(
   Person.CONTENT_URI, 
   "sex=? AND eyecolor=?", 
   new String[]{"male", "blue"});

将搜索整个 person 表,并删除性别为男性且眼睛颜色为蓝色的任何人。

如果 where 子句和 where 值为 null,则 delete() 调用将匹配table 中的每一行。这会导致您看到的行为。

有两种方法可以指定所需的行:

第一个选项,您可以将数字附加到 URI:

cr.delete(
    EarthquakeProvider.CONTENT_URI.buildUpon().appendPath(String.valueOf(_id)).build(),
    null, null);

这将 URI 限制为特定行,并且路径将通过您的case QUAKE_ID:语句,因此无论如何只会删除一行。

第二种选择,您可以使用 where 子句:

cr.delete(EarthquakeProvider.CONTENT_URI, "_id=?", String.valueOf(_id)));

无论哪种方式,您都将根据需要将删除限制为单行。后者使代码更漂亮,但前者更高效,因为 ContentProvider 和 ContentObservers 的工作方式。

最后一点:在您的 ContentProvider 中,您需要添加对 ContentResolver.notifyChange(Uri uri, ContentObserver observer, boolean syncToNetwork) 的调用。这有助于通知游标重新获取数据库查询,并有助于自动化。

于 2011-03-11T19:19:23.357 回答