我正在尝试在我正在开发的 iOS 应用程序中浏览 Core Data 编写的数据。
应用运行一段时间后,我假设收集了一些数据,我现在希望查看数据并查看写入的内容。
我尝试通过从设备获取应用程序容器来获取和浏览 .sqlite 文件(Xcode > Devices > myApp > Download Container...)。
我得到了 db 文件,myAppDB.sqlite 、myAppDB.sqlite-shm 和 myAppDB.sqlite-wal 。
当尝试查看它们时,似乎 .sqlite 是一个空表(除了一些通用的 CoreData/sqlite 东西),而 -wal 文件有所有的信息。
问题是我只能知道 wal 在使用 TextEdit 打开它时具有有用的数据,它无法以非常易读的方式显示它,并且当我尝试使用SQLite Manager 应用程序我警告说 wal 已加密,并要求我输入密码...
重要的是,我正在编写一个处理数据库的框架(模型文件和用于写入数据的代码在框架内),然后我让这个框架在我正在开发的应用程序中运行。这是我用来从框架内创建商店的代码(使用 MagicalRecord ):
NSBundle *frameworkBundle = [NSBundle bundleForClass:[self class]];
[MagicalRecord setDefaultModelNamed"myAppStore.momd" inBundle:frameworkBundle];
NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent"myAppStoreDB.sqlite"];
[MagicalRecord setupCoreDataStackWithStoreAtURL:storeURL];
更新:我设法用 Core-Data-Editor 打开了 sqlite 文件。和 CoreDataUtility但它们都覆盖和删除 .wal 文件的内容,并显示一个空表...它确实有模型(实体名称/属性等)但没有数据。
我的 wal 文件是 873KB,但是当我使用这两个工具之一打开 sqlite 时,它变成了 0Bytes...
tl;dr
如何浏览我正在开发的应用的 Core Data 编写的信息?
Best Answer-推荐答案 strong>
好吧,由于某种原因,我不得不强制在我的商店中不使用 WAL(使用 @"journal_mode""DELETE" 解释为 here)。
然后我只得到了没有 smh 和 wal 文件的 .sqlite 文件,并且能够打开它并使用2 个提到的工具(Core-Data-Editor 和 CoreDataUtility)。
我的猜测是,这与我从框架(创建 moc 、创建实体、保存等)而不是从应用程序处理 CoreData 的事实有关。另一个猜测是它与我使用 MagicalRecord 的事实有关。 .
任何有关原因的见解将不胜感激...
关于ios - 通读我的应用程序的核心数据文件(.sqlite、.sqlite-wal),我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/29598830/
|