Android:使用空间创建的SQLite数据库在使用sqlte-browser打开时不显示任何表

前端之家收集整理的这篇文章主要介绍了Android:使用空间创建的SQLite数据库在使用sqlte-browser打开时不显示任何表前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用Room Persistence Library 1.1.0.我可以使用 Android Studio的Device File Explorer在/ data / data /< package_name> / databases /找到数据库文件.它包含多个表,我可以使用room-DAO访问那些表的内容而没有任何问题.但是当用sqlite-browser打开时,显示没有表.

可能是什么原因?是否有可能在不从房间切换回旧的sqliteOpenHelper的情况下解决问题?

解决方法

要使用sqlite-browser打开此类数据库*,您需要复制所有三个文件.所有人都必须在同一个目录中.

*数据库存储在问题中所述的多个文件中.

为什么三个文件

根据文档,从版本1.1.0开始,Room使用预写日志记录作为具有足够RAM并在API级别16或更高级别上运行的设备的默认日志模式.在此版本之前,所有设备都是Truncate.与Truncate相比,预写日志记录具有不同的内部结构.

现在看一下sqlite使用的文件临时文件

直到版本1.1.0

从1.1.0版开始

如果要将日志模式明确更改为Truncate,可以这样做.但是,不建议这样做,因为与Truncate相比,WAL要好得多.

public static void initialize(Context context) {
    sAppDatabase = Room.databaseBuilder(
            context,AppDatabase.class,DATABASE_NAME)
        .setJournalMode(JournalMode.TRUNCATE).build();
}

是否可以将其移动到单个文件而无需更改为Truncate?

是的.根据数据库查询以下语句.

pragma wal_checkpoint(full)

Here是我自己的相关帖子.

猜你在找的Android相关文章