0

这就是我所拥有的,但它没有说该表不存在。我很肯定它确实可以防止有人问这个问题。但这是执行此操作的一些代码:

什么叫


/*Constants*/
public static final String AUTHORITY = "content://com.smartcal.eventprovider";
private static final int EVENTS_INFO = 1;
baseUri = Uri.withAppendedPath(baseUri, "events_info");
    return new CursorLoader(this, baseUri, args.getStringArray("projection"), 
            args.getString("selection"), args.getStringArray("selectionArgs"), args.getBoolean("sortOrder") ? args.getString("sortOrder") : null );

匹配的是什么


private String getTable(Uri uri) {
    String table = "";
    switch(sUriMatcher.match(uri)){
    case EVENTS_INFO: table = "events_info";
    }
    return table;
}

private static final UriMatcher sUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);

static
{
    sUriMatcher.addURI(AUTHORITY, "events_info", 1);

}

还有我query()的自定义方法ContentProvider


@Override
public Cursor query(Uri uri, String[] projection, String selection,
        String[] selectionArgs, String sortOrder) {
    database = openHelper.getWritableDatabase();

    return database.query(getTable(uri), projection, selection, selectionArgs, null, null, null);
}

错误:


06-19 17:34:14.366: E/AndroidRuntime(686): Caused by: 
java.lang.IllegalStateException: Invalid tables

编辑:

使用 Alex'sIllegalArgumentException时,这是我从错误中得到的结果:

06-19 19:17:42.277: E/AndroidRuntime(1134): Caused by: 
java.lang.IllegalArgumentException: Unknown URI
content://com.smartcal.eventprovider/events_info

如您所知,假设该sUriMatcher.addURI()方法正常工作,它应该匹配。

4

2 回答 2

2

您的问题可能源于您的代码组织得不是很好......

第一件事,

private String getTable(Uri uri) {
    switch(sUriMatcher.match(uri)) {
        case EVENTS_INFO: 
            return "events_info"; // return

        /** PROVIDE A DEFAULT CASE HERE **/
        default:
           // If the URI doesn't match any of the known patterns, throw an exception.
           throw new IllegalArgumentException("Unknown URI " + uri);
    }
}

第二件事,

/** Use constants, not raw ints **/
sUriMatcher.addURI(AUTHORITY, "events_info", EVENT_INFO);

除此之外,您可能还想提供更多信息。

于 2012-06-19T22:32:44.180 回答
0

您是否已经安装了该应用程序并且该表是新的?如果是这样,并且您没有更新 sql 帮助程序类中的架构,则需要先卸载该应用程序。然后在您的模拟器设备中安装该应用程序。db 只创建一次,并且在第一次之后不会调用 sql helper 中的 create 方法,即使您正在安装或运行新的 build/apk。

于 2012-06-19T22:09:06.573 回答