0

我已经使用 DB Browser 创建了一个 SQLite 数据库,当我将它移动到 assets 文件夹并在 android studio 中打开它时,它看起来很糟糕而且它不起作用。解决办法是什么 ?:(

这是一个截图

4

1 回答 1

0

实际上,屏幕截图几乎证实了资产文件夹中的文件是一个有效的 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
  • 第一行来自 SQliteAssetHelper - 它确认数据库是从 assets 文件夹中复制的。
  • 第 2 行显示表 android_metadata,这是将添加的特定于 android 的表,它包含语言环境。
  • 其他几张桌子。
  • 由于约束或隐含约束而自动创建的一些索引
  • 总之一切如预期。
于 2018-12-09T09:20:13.507 回答