我的应用程序上有一个非常完整的数据库。
当需要添加更多功能时,我开始想知道是否应该通过向现有数据库添加更多表来实现它,或者为增加的功能打开一个全新的数据库并在那里添加表。
关于何时开设新数据库是否有任何基本规则?该主题是否有任何基准?
答案 0 :(得分:2)
到了添加更多功能的时候,我开始怀疑 我是否应该通过向现有表添加更多表来实现它 数据库,或为增加的功能打开一个全新的数据库 并在那里添加表格。
关于何时开设新数据库是否有任何基本规则?在那儿 有关该主题的任何基准吗?
所以这是一个非常复杂的问题,取决于更多因素,如应用的性质,所需的表现,表格的特征,它们之间的关系等。
很多人,很多意见所以每个人都可以告诉你一些不同的东西。
但是我的意见是你应该只有一个数据库(也就是将有更多的表e.q. 10-20)。然后还尝试考虑使用Singleton
。
总是更好地拥有一个数据库中的所有表,特别是在这些表有共同点的情况下(有时你需要连接两个或多个表,如果你把表放到另一个数据库中,这个东西将变得不可能) 。你也不知道(现在)你是否会在将来更新表格,改变它们之间的关系等(例如,因为应用程序更新)。另一方面,应用程序的结构也更加干净和可读,就像你在内部或外部存储上有五个*.db
文件一样(我可以说这取决于每个文件的大小,因为放置100 MB。文件到内部存储)。
关于实施的问题:
我建议你(如上所述)只创建一个DatabaseHelper,它将包装所有必需的db逻辑。然后创建名为<?>Tools
的类(一个表的一个类),例如UsersTools,它将包装CRUD
操作和特定表的特定方法。我正在使用这种方法,从来没有遇到过问题。
以下是DatabaseHelper的示例:
package com.sajmon.examples.db;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DataSource extends SQLiteOpenHelper {
private static DataSource instance = null;
public static final String DB_NAME = "<dbname>";
public static final int DB_STARTING_VERSION = 1;
public DataSource(Context cntx) {
super(cntx, DB_NAME, null, DB_STARTING_VERSION);
}
/**
*
* @param mContext as Context of Activity
* @return <li>new instance of }DataSource object.</li>
*/
public static DataSource getInstance(Context mContext) {
if (instance == null) {
instance = new DataSource(mContext);
}
return instance;
}
@Override
public void onCreate(SQLiteDatabase db) {
String query = "create table " + SQLConstants.TEST_TABLE_NAME + " ("
+ SQLConstants.KEY_ID + " integer not null, "
+ SQLConstants.KEY_TYPE + " text null, "
+ SQLConstants.KEY_DATE + " text null" + ")";
db.execSQL(query);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
String query = "drop table if exists " + SQLConstants.TEST_TABLE_NAME;
db.execSQL(query);
onCreate(db);
}
}
<强> SQLConstants:强>
package com.sajmon.examples.db;
public class SQLConstants {
public static final String TEST_TABLE_NAME = "Test";
public static final String KEY_ID = "id";
public static final String KEY_TYPE = "type";
public static final String KEY_DATE = "date";
}
TestTools示例:
package com.sajmon.examples.db;
import java.util.Date;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteStatement;
public class TestTools {
private Context mContext;
private SQLiteDatabase db;
public TestTools(Context mContext) {
this.mContext = mContext;
}
public boolean insert(Test t) throws SQLException {
try {
db = openWrite(DataSource.getInstance(mContext));
ContentValues values = new ContentValues();
if (db != null) {
db.beginTransaction();
values.put(SQLConstants.KEY_ID, t.getId());
values.put(SQLConstants.KEY_TYPE, t.getType());
values.put(SQLConstants.KEY_DATE, t.getDate());
db.insertOrThrow(SQLConstants.TEST_TABLE_NAME, SQLConstants.KEY_TYPE, values);
values.clear();
db.setTransactionSuccessful();
return true;
}
return false;
}
finally {
if (db != null) {
db.endTransaction();
}
close(db);
}
}
public boolean update(Test t) {
try {
db = openWrite(DataSource.getInstance(mContext));
ContentValues values = new ContentValues();
int count = -1;
if (db != null) {
db.beginTransaction();
values.put(SQLConstants.KEY_TYPE, t.getType());
values.put(SQLConstants.KEY_DATE, t.getDate());
count = db.update(SQLConstants.TEST_TABLE_NAME, values, SQLConstants.KEY_ID + "= ?", new String[] {t.getId()});
db.setTransactionSuccessful();
}
return count > 0;
}
finally {
if (db != null) {
db.endTransaction();
close(db);
}
}
}
public boolean delete(Test t) {
int count = -1;
try {
db = openWrite(DataSource.getInstance(mContext));
if (db != null) {
db.beginTransaction();
count = db.delete(SQLConstants.TEST_TABLE_NAME, SQLConstants.KEY_ID + "= ?", new String[] {t.getId()});
db.setTransactionSuccessful();
}
return count > 0;
}
finally {
if (db != null)
db.endTransaction();
close(db);
}
}
}
public List<Test> getAll() {
Cursor c = null;
List<Test> tests = new ArrayList<Test>();
Test test = null;
try {
db = openRead(DataSource.getInstance(mContext));
if (db != null) {
String[] columns = {SQLConstants.KEY_ID, SQLConstants.KEY_TYPE, SQLConstants.KEY_DATE};
c = db.query(SQLConstants.TEST_TABLE_NAME, columns, null, null, null, null, null);
if (c.moveToFirst()) {
do {
test = new Test();
test.setId(c.getInt(c.getColumnIndex(SQLConstants.KEY_ID)));
test.setType(c.getString(c.getColumnIndex(SQLConstants.KEY_TYPE)));
test.setDate(c.getString(c.getColumnIndex(SQLConstants.KEY_DATE)));
tests.add(test);
} while(c.moveToNext());
}
}
return tests;
}
finally {
if (c != null) {
c.close();
}
if (db != null) {
close(db);
}
}
}
private final synchronized SQLiteDatabase openWrite(SQLiteOpenHelper handler) {
return handler.getWritableDatabase();
}
private final synchronized SQLiteDatabase openRead(SQLiteOpenHelper handler) {
return handler.getReadableDatabase();
}
private final synchronized void close(SQLiteDatabase db) {
if (db != null && db.isOpen()) {
db.close();
}
}
}
这是基于个人要求可以修改/改进的基本实施示例。如果你想“在更抽象的层面上”实现,那么DAOFactory
设计模式应该是最好的选择。
注意:从其他Android开发人员获得经验非常有用,然后开始考虑并决定合适的方法。