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性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...