2

我想从 Android 的内部数据库表中删除一个条目ContactsContract,即应该从联系人的条目中删除诸如生日之类的事件。

以下代码运行良好,但一些用户(约 1%)会因SQLException. 那么我的代码有什么问题,还是只是他们的设备不ContactsContract正确支持Android?

try {
    ArrayList<Long> rawContactIDs = getRawContactID(o.getID());
    int rawContactCount = rawContactIDs.size();
    for (int r = 0; r < rawContactCount; r++) {
        long rawContactID = rawContactIDs.get(r);
        String where = ContactsContract.Data.MIMETYPE+" = ? AND "+ContactsContract.Data.RAW_CONTACT_ID+" = ? AND "+ContactsContract.CommonDataKinds.Event.TYPE+" = ?";
        String[] selection = new String[] { ContactsContract.CommonDataKinds.Event.CONTENT_ITEM_TYPE, String.valueOf(MY_RAW_CONTACT_ID), String.valueOf(ContactsContract.CommonDataKinds.Event.TYPE_BIRTHDAY) };
        getContentResolver().delete(ContactsContract.Data.CONTENT_URI, where, selection);
    }
}
catch (Exception e) {}

抛出的异常是:

android.database.sqlite.SQLiteException: no such column: mimetype: , while
compiling: DELETE FROM data WHERE mimetype = ? AND raw_contact_id = ? AND
data2 = ?
at
android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:158)
at
android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:114)
at
android.content.ContentProviderProxy.delete(ContentProviderNative.java:472)
at android.content.ContentResolver.delete(ContentResolver.java:700)
at ... MY_ACTIVITY ...
4

2 回答 2

1

设备制造商可以更改ContentProviderAOSP 随附的 a 的实现。理论上,兼容性测试套件 (CTS) 会捕获这些更改,因此只有不破坏 API 的设备才能在通过 Play 商店交付时运行您的应用程序。

话虽如此...

  • CTS 远未完成
  • 如果您故意将您的应用分发到 Play 商店之外,并且有人使用不兼容的设备运行您的应用,则 CTS 不会保护您
  • 如果您无意中将您的应用程序分发到 Play 商店之外(即您的应用程序已被盗版),并且有人使用不兼容的设备运行您的应用程序,CTS 不会为您提供保护
  • 各种设备制造商盗版 Play Store 应用程序本身

因此,当您看到似乎源自操作系统提供ContentProvider的问题,但这些问题并不常见和/或出现在无法识别的设备上时,请不要惊慌。在这种情况下,您仍然可以选择以某种方式优雅地失败(通过将失败的调用包装在您自己的异常处理程序中),但您的代码不太可能真的是困难的根源。

于 2012-08-26T11:17:18.643 回答
1

ContactsContract API从第5 级开始可用。报告此问题的用户是否可能低于第 5 级(甜甜圈、纸杯蛋糕)?

于 2012-08-23T17:33:10.377 回答