gpt4 book ai didi

用于测试 SQLite 架构更新的 Android ADB

转载 作者:行者123 更新时间:2023-11-30 03:59:35 25 4
gpt4 key购买 nike

[更新:解决方案 = 修复了 onUpgrade() 代码,该代码允许使用调试器成功测试数据库架构更改,而不是打包多个 apk]

我正在尝试测试 2 个 apk 以确保在我的应用程序更新部署到 Market 时会发生数据库更新。

Test1.apk:包含 sqlite schema_version = 1Test2.apk:包含 sqlite schema_version = 2

两个 apk 都使用相同的 key 进行数字签名,使用 adb 我能够安装 Test1.apk。当我尝试安装 Test2.apk 时,我收到:

失败 [INSTALL_FAILED_ALREADY_EXISTS]

如何测试我的新架构更改?如果答案来自调试器,那么当调用 onUpgrade() 时,我的数据库始终处于锁定状态。

//////////////// This Code Fixed The onUpgrade() Issue /////////////////////

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//TODO: Write DB Update logic.

SQLiteDatabase upgradeDB = null;

if (newVersion > oldVersion){
Log.e(TAG, "NEWER VERSION DETECTED, DATABASE UPGRADE REQUIRED!");

InputStream inputStream = myContext.getResources().openRawResource(R.raw.dbscript_v2_0_0_0);
BufferedReader br2 = new BufferedReader(new InputStreamReader(inputStream), 1016688); //1016688 max
String buffer;
try {

db.beginTransaction();

//openDataBase();
while ((buffer = br2.readLine()) != null)
{
String[] execSql = buffer.split("\n");
execMultipleSQL(db, execSql);

}
db.setTransactionSuccessful();

Log.d(TAG, "onCreated sql: CREATED TABLES and INSERTED RECORDS");
} catch (SQLException e) {
Log.e("Error creating tables and debug data", e.toString());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
db.endTransaction();
//db.close();
}

}
else
{
Log.e(TAG, "NO DATABASE UPGRADE DETECTED");
}
}

////////////////////////////////////////////////////////////////////////////


@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//TODO: Write DB Update logic.

SQLiteDatabase upgradeDB = null;

if (newVersion > oldVersion){
Log.e(TAG, "NEWER VERSION DETECTED, DATABASE UPGRADE REQUIRED!");

InputStream inputStream = myContext.getResources().openRawResource(R.raw.dbscript_v2_0_0_0);
BufferedReader br2 = new BufferedReader(new InputStreamReader(inputStream), 1016688); //1016688 max
String buffer;
try {

String myPath = DATABASE_PATH + DATABASE_NAME;
myDataBase = SQLiteDatabase.openOrCreateDatabase(DATABASE_PATH + DATABASE_NAME, null);
myDataBase.beginTransaction();

//openDataBase();
while ((buffer = br2.readLine()) != null)
{
String[] execSql = buffer.split("\n");
execMultipleSQL(myDataBase, execSql);

}
myDataBase.setTransactionSuccessful();
//close();
Log.d(TAG, "onCreated sql: CREATED TABLES and INSERTED RECORDS");
} catch (SQLException e) {
Log.e("Error creating tables and debug data", e.toString());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
myDataBase.endTransaction();
myDataBase.close();
}

}
else
{
Log.e(TAG, "NO DATABASE UPGRADE DETECTED");
}
}


public void openDataBase() throws SQLException {

try
{
/* When the database is 1st installed on the device, this helper class creates a blank database using getWritableDatabase().
* The actual database is then populated using the SQLiteDatabase.openDatabase(PATH, null, Open_ReadWrite) to exec the sql.
*
* PROBLEM - SQLiteDatabase.openDatabase() Does not call onUpgrade() so we're
* unable to update the database for future versions
*
* SOLUTION - Check to see if the dbExists, if not use SQLiteDatabase.openDatabase()
* because it will create the DB from scripts, we don't care about onUpgrade();
* If the db does exist, call getWritableDatabase() to invoke onUpgrade checks for
* future releases where the SCHEMA_VERSION is greater than the current db SCHEMA_VERSION
*/
boolean dbExist = checkDataBase();
if(!dbExist){

/* Calls: DOES NOT call onUpgrade()
* Errors if db exists and there are db changes (New Columns/Tables), so use the below getWritableDatabase() instead */
String myPath = DATABASE_PATH + DATABASE_NAME;
myDataBase = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READWRITE);
}
else
{
/* Calls: onUpgrade()
* Errors if db does not exist, so use the above instead */
myDataBase = this.getWritableDatabase();
}

}
catch (Exception e) {
Log.e(TAG, "Error SQLiteFactoryAdapter openDataBase " + e.toString());
}
}

最佳答案

你是如何打开数据库的?

看起来您正在扩展 SQLiteOpenHelper。构造函数有一个参数 version,代表模式的版本。你为什么不在你的测试中改变这个参数来测试你的 onUpgrade() 方法

旁注:您收到错误消息的原因是因为您正在尝试再次部署相同的包。您需要先卸载它,然后再重新部署它。您可以使用命令 adb uninstall packagename.apk 执行此操作。

关于用于测试 SQLite 架构更新的 Android ADB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12716885/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com