CoreData: 错误: (14) 数据库 I/O 错误

     2023-03-04     248

关键词:

【中文标题】CoreData: 错误: (14) 数据库 I/O 错误【英文标题】:CoreData: error: (14) I/O error for database 【发布时间】:2013-09-12 20:08:50 【问题描述】:

在 XCode 中使用 Core Data 编译和运行项目时,我遇到了一个以前从未见过的错误:

 2013-09-12 16:59:10.156 myapp[57811:70b] CoreData: error: 
      (14) I/O error for database at /Users/administrador/Library/
         Application Support/iPhone Simulator/7.0/Applications/
         6BA67336-B093-46CF-8B11-E3595409DAC2/myapp.app/database.sqlite.  

         SQLite error code:14, 'unable to open database file'

生成此消息的代码是:

    psc = [[NSPersistentStoreCoordinator alloc]
                   initWithManagedObjectModel:self.managedObjectModel];
    NSURL *storeURL = [[NSBundle mainBundle] 
                         URLForResource:@"database" withExtension:@"sqlite"];
    [psc addPersistentStoreWithType:NSSQLiteStoreType 
             configuration:nil URL:storeURL 
             options:@NSReadOnlyPersistentStoreOption : @YES error:NULL];

我试过Build->Clean,删除派生数据,卸载应用。

我在发帖前检查了this question,我相信问题有所不同。

注意: sqlite 是应用的资源

使用调试建议的信息

2013-09-12 17:43:38.341 myapp[58322:70b] CoreData: annotation: Connecting to sqlite database file at "/Users/administrador/Library/Application Support/iPhone Simulator/7.0/Applications/6BA67336-B093-46CF-8B11-E3595409DAC2/myapp.app/database.sqlite"
2013-09-12 17:43:38.360 myapp[58322:70b] CoreData: sql: SELECT Z_VERSION, Z_UUID, Z_PLIST FROM Z_METADATA
2013-09-12 17:43:38.363 myapp[58322:70b] CoreData: annotation: Disconnecting from sqlite database due to an error.
2013-09-12 17:43:38.364 myapp[58322:70b] CoreData: error: (14) I/O error for database at /Users/administrador/Library/Application Support/iPhone Simulator/7.0/Applications/6BA67336-B093-46CF-8B11-E3595409DAC2/myapp.app/database.sqlite.  SQLite error code:14, 'unable to open database file'
2013-09-12 17:43:38.366 myapp[58322:70b] CoreData: annotation: Disconnecting from sqlite database.

【问题讨论】:

【参考方案1】:

现在 iOS7 上的 NDA 已经解除,我可以发布我为这个问题找到的解决方法。

iOS7中的Core Data默认使用WAL中的sqlite

唯一有效的解决方案是使用没有WAL的iOS6模拟器创建sqlite并将其导入项目中:

- (NSPersistentStoreCoordinator *)persistentStoreCoordinator

    static NSPersistentStoreCoordinator *psc;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^
        psc = [[NSPersistentStoreCoordinator alloc] 
                 initWithManagedObjectModel:self.managedObjectModel];
        NSURL *storeURL = [[NSBundle mainBundle] 
                  URLForResource:@"database" withExtension:@"sqlite"];
        [psc addPersistentStoreWithType:NSSQLiteStoreType
                          configuration:nil
                                    URL:storeURL
                                options:@NSReadOnlyPersistentStoreOption : @YES,
                             NSSQLitePragmasOption: @@"journal_mode":@"DELETE"
                                  error:NULL];
    );
    return psc;

【讨论】:

这里更容易禁用 WAL:***.com/a/18870738/288860 非常感谢,一直在网上寻找解决方案。令人沮丧的是,在 IOS 中使用预填充只读数据库的文档是如此缺乏。【参考方案2】:
NSURL *storeURL = [[NSBundle mainBundle] 
                     URLForResource:@"database" withExtension:@"sqlite"];

在应用程序包内构建一个只读路径。持久存储 文件需要驻留在可写目录中,例如“文档”目录。

编辑:上述答案实际上是错误的,可以从应用程序包中打开一个只读核心数据文件(使用NSReadOnlyPersistentStoreOption)。我目前唯一能想到的是 捆绑的文件不是有效的核心数据数据库。添加启动参数

-com.apple.CoreData.SQLDebug 1

可能有助于定位问题。

【讨论】:

虽然您可能是对的,但它无法从只读位置打开只读数据库不寻常的。 它总是有效的。我不确定为什么只读数据库必须驻留在 Documents 中 @ppaulojr:你是对的(我写这个答案太快了 :-) - 捆绑的文件可能不是有效的 Core Data 数据库(与当前模型匹配)吗? @ppaulojr:也许添加启动参数“-com.apple.CoreData.SQLDebug 1”以获取更多信息。 我添加了来自SQLDebug的信息

即使没有更多实体,CoreData/Entity 错误也不会消失

】即使没有更多实体,CoreData/Entity错误也不会消失【英文标题】:CoreData/Entityerrordoesnotdisappeareventhoughthereisnomoreentity【发布时间】:2017-07-0406:14:14【问题描述】:我面临CoreData相关问题,并且不断收到此错误消息:Command/Applications... 查看详情

CoreData 严重应用错误

】CoreData严重应用错误【英文标题】:CoreDataseriousapplicationerror【发布时间】:2014-07-2817:14:25【问题描述】:每隔一段时间,我都会在我的应用程序中收到以下错误消息。这发生在我的应用程序通过带有CoreData集成的RestKit接收到Web... 查看详情

从 Coredata 中删除一个对象(出现错误)

】从Coredata中删除一个对象(出现错误)【英文标题】:deleteanobjectfromCoredata(gettinganerror)【发布时间】:2015-07-1212:56:14【问题描述】:我尝试从coredata中删除与Test2匹配的对象。我试过这个:letcontext=self.fetchedResultsController.managedObj... 查看详情

Coredata 错误“数据:<故障>”

】Coredata错误“数据:<故障>”【英文标题】:CoredataError"data:<fault>"【发布时间】:2011-09-0505:46:37【问题描述】:我尝试使用以下代码从CoreData中提取数据NSFetchRequest*request=[[NSFetchRequestalloc]init];request.entity=[NSEntityDe... 查看详情

CoreData:错误:严重的应用程序错误。在核心数据更改处理期间捕获到异常

】CoreData:错误:严重的应用程序错误。在核心数据更改处理期间捕获到异常【英文标题】:CoreData:error:Seriousapplicationerror.ExceptionwascaughtduringCoreDatachangeprocessing【发布时间】:2013-01-0307:36:01【问题描述】:我在开发我的iphone应用... 查看详情

简单添加到数据库的 CoreData 错误

】简单添加到数据库的CoreData错误【英文标题】:CoreDataerrorsforsimpleaddingtodatabase【发布时间】:2012-10-1620:13:18【问题描述】:编辑:我试图找出的错误消息位于代码的右侧,列为cmets!!!Xcode不断尝试提出替代方案并拒绝让我构建。... 查看详情

添加新属性时,CoreData 无法完成错误

】添加新属性时,CoreData无法完成错误【英文标题】:CoreDatacouldnotfulfillafaultwhenaddingnewattribute【发布时间】:2010-03-1121:12:55【问题描述】:我在尝试访问新数据模型中的新属性时收到“CoreData无法满足...的错误”错误消息。如果... 查看详情

CoreData:错误:严重的应用程序错误。在核心数据更改处理期间捕获到异常

】CoreData:错误:严重的应用程序错误。在核心数据更改处理期间捕获到异常【英文标题】:CoreData:error:Seriousapplicationerror.ExceptionwascaughtduringCoreDatachangeprocessing【发布时间】:2013-11-1904:40:42【问题描述】:嗨,我要崩溃了,当我... 查看详情

从 CoreData 获取数据时出现“'[AnyObject]' 不可转换为 '[Dog]?'”错误

】从CoreData获取数据时出现“\\\'[AnyObject]\\\'不可转换为\\\'[Dog]?\\\'”错误【英文标题】:"\'[AnyObject]\'isnotconvertibleto\'[Dog]?\'"errorwhenfetchingdatafromCoreData从CoreData获取数据时出现“\'[AnyObject]\'不可转换为\'[Dog]?\'”错误【发布时... 查看详情

CoreData错误如何写回核心数据

】CoreData错误如何写回核心数据【英文标题】:CoreDataerrorhowtowritecoredataback【发布时间】:2013-11-0123:15:48【问题描述】:我只是想了解核心数据。我已经设法在applicationDidFinishLaunching中加载了一些数据,但现在我想做一些更复杂的... 查看详情

从实体中删除属性后迁移 CoreData 时出错

】从实体中删除属性后迁移CoreData时出错【英文标题】:ErrormigratingCoreDataafterdeletedattributefromentity【发布时间】:2015-11-1221:08:14【问题描述】:我的默认数据模型有一个属性(sectionNumber),我从实体(Tip)中删除了该属性。该实体在之... 查看详情

coredata 错误,因为 sectionNameKeyPath 或 NSFetchedResultsController 处的分组数据

】coredata错误,因为sectionNameKeyPath或NSFetchedResultsController处的分组数据【英文标题】:coredataerrorbecausesectionNameKeyPathorgroupingdataatNSFetchedResultsController【发布时间】:2011-12-2804:01:22【问题描述】:2011-12-2810:52:13.633BadgerNew[663: 查看详情

仅在 iOS 14 中崩溃核心数据

】仅在iOS14中崩溃核心数据【英文标题】:CrashCoreDataonlyiniOS14【发布时间】:2020-09-2116:29:53【问题描述】:我在一个使用CoreData的应用程序上工作,在iOS13和iOS14上一切正常,具有不同的Xcode测试版。但自从Apple发布了iOS14和Xcode12的... 查看详情

iOS:更新数据时出现CoreData异常

...2012-03-2307:49:14【问题描述】:我正在尝试使用CoreData更新数据库中的现有记录,但在使用托管对象访问器方法时出现异常。代码摘录:NSManagedObjectContext*tmpManagedObjectContext=[self.fetchedResultsCont 查看详情

使用嵌套数据更新 CoreData 对象时,RestKit 验证失败(Cocoa 错误 1550)

】使用嵌套数据更新CoreData对象时,RestKit验证失败(Cocoa错误1550)【英文标题】:RestKitvalidationfailingwhenupdatingCoreDataobjectwithnesteddata(Cocoaerror1550)【发布时间】:2014-09-0320:28:50【问题描述】:我正在编写一个单元测试来检查我的Core... 查看详情

SwiftUI 2.0 / CoreData 2021:没有错误但实体未保存

】SwiftUI2.0/CoreData2021:没有错误但实体未保存【英文标题】:SwiftUI2.0/CoreData2021:Noerrorbutentitynotsaved【发布时间】:2021-02-2409:37:02【问题描述】:我有一个SwiftUI2.0应用程序,它使用CoreData在本地存储数据,虽然当我尝试在版本视图... 查看详情

NSIndexPath:从 CoreData 检索数据

...dexPath值传递给另一个swift文件。由于两个文件都从同一个数据库中获 查看详情

为啥 deleteObject: 导致 CoreData 故障?

】为啥deleteObject:导致CoreData故障?【英文标题】:WhydoesdeleteObject:causeCoreDatafaults?为什么deleteObject:导致CoreData故障?【发布时间】:2016-03-0308:28:14【问题描述】:我有一个清理例程,它清除了一堆托管对象,形成一些似乎触发很... 查看详情