我要将数据库架构升级到新版本。在这样做之前,首先我需要从现有数据库中获取一些数据。问题在于,如果我尝试使用以下内容读取数据库:
DatabaseHelper dbHelper = new DatabaseHelper(context, DB_VERSION);
SQLiteDatabase database = dbHelper.getReadableDatabase();
它可能会被升级(在
DatabaseHelper.onUpgrade()
中),这是一种不必要的行为,因为我只想从旧的、未升级的版本中提取一些记录。我想我可以通过在db_版本中传递当前版本来实现这一点,但如何才能获得数据库的当前版本(记住,我正在将整个应用程序升级到下一个版本)?或者有没有其他方法可以从数据库中获取一些记录而不会导致升级?
最佳答案
直接使用SQLiteDatabase
并执行查询以获取版本。它不会尝试升级或修改它。打开只读以获得额外保护:)