考虑:
public static final String NOTE_ID = "_id";
public static final String TITLE = "title";
public static final String TEXT = "text";
上面显示的我的 sqlite 数据库中的 3 列用于内容提供程序,我在下面的代码中将它们放在哪里?最好的地方在哪里?
我应该在扩展 BaseColumns 的 NoteItems 类中添加什么?
有点困惑在哪里放什么。
public class ProviderExample extends ContentProvider {
private static final String DATABASE_NAME = "notes.db";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "notes";
public static final String AUTHORITY = "package com.example.contentproviderexample.providerexample";
public static final UriMatcher sUriMatcher;
private static final int NOTES = 1;
private static final int NOTES_ID = 2;
public static final Uri CONTENT_URI = Uri.parse("content://"
+ AUTHORITY + "/notes");
static final String SINGLE_RECORD = "vnd.android.cursor.item/vnd.example.providerexample";
static final String MULTIPLE_RECORDS = "vnd.android.cursor.dir/vnd.example.providerexample";
static {
sUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
sUriMatcher.addURI(AUTHORITY, TABLE_NAME, NOTES);
sUriMatcher.addURI(AUTHORITY, TABLE_NAME + "/#", NOTES_ID);
}
public static interface NoteItems extends BaseColumns { }
private static class DatabaseHelper extends SQLiteOpenHelper{
DatabaseHelper(Context context)
{
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {}
@Override
public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
// TODO Auto-generated method stub
}
} // DatabaseHelper
编辑:
我缩小了选择范围。看起来最好有 2 个地方放置此代码。一个是在 ProviderExample 中扩展 ContentProvider 类以及其他变量,另一个位置是在 DatabaseHelper 中扩展 SQLiteOpenHelper 类,两者都是可能的,但我不知道这两个地方哪个更正确。我找到了两种使用方式的例子。