Я читал учебник по Android-платформе Android SQLite, который ссылался на создание класса адаптера базы данных для создания и доступа к таблице БД. При работе с базами данных SQLite с несколькими таблицами лучше всего создать другой класс адаптера для каждой таблицы или создать один класс адаптера DB для всего приложения для Android?
Мое приложение использует несколько таблиц, и я надеялся, что не должен иметь один массивный класс адаптеров. проблема в том, что у меня есть вложенный подкласс SQLiteOpenHelper для примера NotePad в каждом адаптере. Когда открывается первая таблица, все работает нормально. Когда я пытаюсь получить доступ ко второй области (из-за другого действия), мое приложение вылетает.
Сначала я думал, что авария вызвана проблемой проверки версий, но оба адаптера теперь имеют одну и ту же версию базы данных и все еще сбой.
Вот пример одного из адаптеров DB для таблицы. Другие адаптеры соответствуют одному и тому же формату с различными реализациями.
public class InfoDBAdapter {
public static final String ROW_ID = "_id";
public static final String NAME = "name";
private static final String TAG = "InfoDbAdapter";
private static final String DATABASE_NAME = "myappdb";
private static final String DATABASE_TABLE = "usersinfo";
private static final int DATABASE_VERSION = 1;
private static final String DATABASE_CREATE = "create table usersinfo (_id integer primary key autoincrement, "
+ NAME
+ " TEXT," + ");";
private DatabaseHelper mDbHelper;
private SQLiteDatabase mDb;
private final Context mCtx;
private static class DatabaseHelper extends SQLiteOpenHelper {
DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(DATABASE_CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w(TAG, "Upgrading database from version " + oldVersion + " to " //$NON-NLS-1$//$NON-NLS-2$
+ newVersion + ", which will destroy all old data"); //$NON-NLS-1$
//db.execSQL("DROP TABLE IF EXISTS usersinfo"); //$NON-NLS-1$
onCreate(db);
}
}
public InfoDBAdapter(Context ctx) {
this.mCtx = ctx;
}
public InfoDBAdapter open() throws SQLException {
this.mDbHelper = new DatabaseHelper(this.mCtx);
this.mDb = this.mDbHelper.getWritableDatabase();
return this;
}
/**
* close return type: void
*/
public void close() {
this.mDbHelper.close();
}
public long createUser(String name) {
ContentValues initialValues = new ContentValues();
initialValues.put(NAME, name);
return this.mDb.insert(DATABASE_TABLE, null, initialValues);
}
public boolean deleteUser(long rowId) {
return this.mDb.delete(DATABASE_TABLE, ROW_ID + "=" + rowId, null) > 0; //$NON-NLS-1$
}
public Cursor fetchAllUsers() {
return this.mDb.query(DATABASE_TABLE, new String[] { ROW_ID,
NAME}, null, null, null, null, null);
}
public Cursor fetchUser(long rowId) throws SQLException {
Cursor mCursor =
this.mDb.query(true, DATABASE_TABLE, new String[] { ROW_ID, NAME}, ROW_ID + "=" + rowId, null, //$NON-NLS-1$
null, null, null, null);
if (mCursor != null) {
mCursor.moveToFirst();
}
return mCursor;
}
public boolean updateUser(long rowId, String name) {
ContentValues args = new ContentValues();
args.put(NAME, name);
return this.mDb
.update(DATABASE_TABLE, args, ROW_ID + "=" + rowId, null) > 0; //$NON-NLS-1$
}
}
Когда первый адаптер, в этом случае userinfo, доступен, все работает так, как ожидалось. Скажем, у меня есть другой адаптер для информации о друге, который следует той же структуре, что и выше, когда к нему обращается другое действие, мне кажется, что вложенный подкласс SQLiteOpenHelper попытается снова создать базу данных. Очевидно, что-то не так, потому что в этом случае мое приложение вылетает.
Итак, стандартная практика в Android для создания одного адаптера мамонтового db вместо отдельных адаптеров для таблицы?