我已经使用 DB Browser 创建了一个 SQLite 数据库,当我将它移动到 assets 文件夹并在 android studio 中打开它时,它看起来很糟糕而且它不起作用。解决办法是什么 ?:(
这是一个截图
我已经使用 DB Browser 创建了一个 SQLite 数据库,当我将它移动到 assets 文件夹并在 android studio 中打开它时,它看起来很糟糕而且它不起作用。解决办法是什么 ?:(
这是一个截图
实际上,屏幕截图几乎证实了资产文件夹中的文件是一个有效的 SQLite 数据库。
即前 16 个字节与数据库头匹配头字符串:“SQLite 格式 3\000” 数据库文件格式。
Android Studio 本身不包括将文件作为 SQLite 数据库实际打开的要求(有一些工具,例如 DB Browser 可以做到这一点)。
您需要使用您的应用程序将文件作为 SQLiteDatabase 打开。这通常通过将文件从资产文件夹复制到合适的位置来完成(因为资产文件夹是包的一部分,它是只读的),然后通常通过 SQLiteOpenHelper 的子类从该位置打开它。
有一个可用的类,即SQLiteAssetHelper,可以使打开数据库相对容易。请注意,SQLiteAssetHelper 期望数据库(名称与包含扩展名的文件名相同)位于资产文件夹的数据库文件夹中(您可能必须创建此文件夹,尽管屏幕截图显示您已将数据库放入数据库中文件夹)。
以下是使用 SQliteAssethelper 打开数据库的快速示例,在这种情况下,根据 sqlite_master(SQlite 的主表)列出项目(表、视图、索引、触发器等)。
Build.gradle(App)(其中的一部分):-
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'com.android.support:appcompat-v7:28.0.0'
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
implementation 'com.readystatesoftware.sqliteasset:sqliteassethelper:+' //<<<<<<<<<< ADDED JUST THIS LINE
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}
DatabaseHelper(SQLiteAssethelper 的子类)DBHelper.java
public class DBHelper extends SQLiteAssetHelper {
public static final String DBNAME = "DaycareCenters.db";
public static final int DBVERSION = 1;
SQLiteDatabase mDB;
public DBHelper(Context context) {
super(context, DBNAME, null, DBVERSION);
mDB = this.getWritableDatabase();
}
}
一个调用活动(例如)MainActivity.java
public class MainActivity extends AppCompatActivity {
DBHelper mDBHlpr;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mDBHlpr = new DBHelper(this);
Cursor csr = mDBHlpr.mDB.rawQuery("SELECT * FROM sqlite_master",null);
while (csr.moveToNext()) {
Log.d("SQLITEMASTER","Name = " + csr.getString(csr.getColumnIndex("name")) + " Type = " + csr.getString(csr.getColumnIndex("type")));
}
csr.close();
}
}
.
12-09 09:55:19.760 1473-1473/? I/SQLiteAssetHelper: successfully opened database DaycareCenters.db
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = android_metadata Type = table
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = player_card Type = table
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = sqlite_autoindex_player_card_1 Type = index
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = email Type = table
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = region Type = table
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = card Type = table
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = pc Type = table
12-09 09:55:19.764 1473-1473/? D/SQLITEMASTER: Name = sqlite_autoindex_pc_1 Type = index