Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/objective-c/23.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ios 核心数据-数据故障_Ios_Objective C_Core Data_Save - Fatal编程技术网

Ios 核心数据-数据故障

Ios 核心数据-数据故障,ios,objective-c,core-data,save,Ios,Objective C,Core Data,Save,我正在将数据保存到核心数据、更新、删除等。 关于核心数据和保存,我没有任何错误。 但是当我试图打开sqlite数据库文件时,那里什么都没有,也没有更新和保存到核心数据的内容 AppDelegate: - (void)saveContext { NSError *error = nil; NSManagedObjectContext *managedObjectContext = self.managedObjectContext; if (managedObjectCon

我正在将数据保存到核心数据、更新、删除等。 关于核心数据和保存,我没有任何错误。 但是当我试图打开sqlite数据库文件时,那里什么都没有,也没有更新和保存到核心数据的内容

AppDelegate:

- (void)saveContext
{
    NSError *error = nil;
    NSManagedObjectContext *managedObjectContext = self.managedObjectContext;
    if (managedObjectContext != nil) {
        if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) {
            // Replace this implementation with code to handle the error appropriately.
            // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
            NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
            abort();
        }
    }
}

// Returns the managed object context for the application.
// If the context doesn't already exist, it is created and bound to the persistent store coordinator for the application.
- (NSManagedObjectContext *)managedObjectContext
{
    if (_managedObjectContext != nil) {
        return _managedObjectContext;
    }

    NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator];
    if (coordinator != nil) {
        _managedObjectContext = [[NSManagedObjectContext alloc] init];
        [_managedObjectContext setPersistentStoreCoordinator:coordinator];
    }
    return _managedObjectContext;
}

// Returns the managed object model for the application.
// If the model doesn't already exist, it is created from the application's model.
- (NSManagedObjectModel *)managedObjectModel
{
    if (_managedObjectModel != nil) {
        return _managedObjectModel;
    }
    NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"CoreDataModel" withExtension:@"momd"];
    _managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
    return _managedObjectModel;
}

// Returns the persistent store coordinator for the application.
// If the coordinator doesn't already exist, it is created and the application's store added to it.
- (NSPersistentStoreCoordinator *)persistentStoreCoordinator
{
    if (_persistentStoreCoordinator != nil) {
        return _persistentStoreCoordinator;
    }

    NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"CoreDataModel.sqlite"];

    NSError *error = nil;
    _persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
    if (![_persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {
        NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
        abort();
    }

    return _persistentStoreCoordinator;
}

#pragma mark - Application's Documents directory

// Returns the URL to the application's Documents directory.
- (NSURL *)applicationDocumentsDirectory
{
    return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
}
更新核心数据的示例:

- (void)enableORdisableAlertInDatabase:(FMDatabase*)database andOperation:(int)operation andTrapID:(int)trapID
{
    NSLog(@"%s", __PRETTY_FUNCTION__);

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
    NSEntityDescription *entity = [NSEntityDescription entityForName:kCORE_DATA_TRAP_ENTITY inManagedObjectContext:appDelegate.managedObjectContext];
    [fetchRequest setEntity:entity];
    // Specify criteria for filtering which objects to fetch
    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"trapID==%i", trapID];
    [fetchRequest setPredicate:predicate];

    NSError *error = nil;
    NSArray *fetchedObjects = [appDelegate.managedObjectContext executeFetchRequest:fetchRequest error:&error];
    if (fetchedObjects == nil) {
        NSLog(@"%s error: %@", __PRETTY_FUNCTION__, error.localizedDescription);
    }
    else {
        CoreDataTrap *trap = (CoreDataTrap*)fetchedObjects.firstObject;
        [trap setAlert:[NSNumber numberWithInt:operation]];

        [appDelegate.managedObjectContext save:&error];

        if (error != nil) {
            NSLog(@"enableORdisableAlertInDatabase Error: %@", error.localizedDescription);
        }
    }
}
"<CoreDataTrap: 0x147c4140> (entity: CoreDataTrap; id: 0x1477d510 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p11> ; data: <fault>)",
    "<CoreDataTrap: 0x147c4240> (entity: CoreDataTrap; id: 0x1477d520 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p12> ; data: <fault>)",
    "<CoreDataTrap: 0x145507d0> (entity: CoreDataTrap; id: 0x147cd410 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p13> ; data: <fault>)",
    "<CoreDataTrap: 0x14550900> (entity: CoreDataTrap; id: 0x147cd420 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p14> ; data: <fault>)",
    "<CoreDataTrap: 0x14550a30> (entity: CoreDataTrap; id: 0x147cd430 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p15> ; data: <fault>)",
    "<CoreDataTrap: 0x145401b0> (entity: CoreDataTrap; id: 0x147cd440 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p16> ; data: <fault>)",
    "<CoreDataTrap: 0x145402b0> (entity: CoreDataTrap; id: 0x147cd450 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p17> ; data: <fault>)",
    "<CoreDataTrap: 0x14540440> (entity: CoreDataTrap; id: 0x147cd460 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p18> ; data: <fault>)",
    "<CoreDataTrap: 0x1453e380> (entity: CoreDataTrap; id: 0x147cd470 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p19> ; data: <fault>)",
    "<CoreDataTrap: 0x1453e480> (entity: CoreDataTrap; id: 0x147cd480 <x-coredata://CD85E666-FA17-4D5F-A221-9BC962C7667B/CoreDataTrap/p20> ; data: <fault>)"
编辑: 以下是添加或更新对象的函数:

- (void)addOrUpdateTrap:(Traps*)trapObject
{
    int trapID = trapObject.getTrapID;
    CoreDataTrap *trapEntity = nil;
    NSError *error = nil;

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] initWithEntityName:@"CoreDataTrap"];
    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"trapID == %d", trapID];
    [fetchRequest setPredicate:predicate];

    NSArray *results = [appDelegate.managedObjectContext executeFetchRequest:fetchRequest error:&error];
    if (results == nil)
    {
        // Handle error
    }
    else if ([results count] == 0)
    {
        // Nothing to update, add new trap
        // Create a new record (row)
        trapEntity = [NSEntityDescription insertNewObjectForEntityForName:@"CoreDataTrap" inManagedObjectContext:appDelegate.managedObjectContext];
    }
    else
    {
        trapEntity = results[0]; // There should be only one object for the ID.
    }


    if (trapEntity != nil)
    {
        // Set properties for new or existing object ...

        // Int
        [trapEntity setTrapID:[NSNumber numberWithInt:trapObject.getTrapID]];
        [trapEntity setType:[NSNumber numberWithInt:trapObject.getTrapType]];
        [trapEntity setDist:[NSNumber numberWithInt:trapObject.getTrapDistanceToCar]];
        [trapEntity setDist_to_close_point:[NSNumber numberWithInt:trapObject.getTrapDistanceToClosePoint]];
        [trapEntity setActive:[NSNumber numberWithInt:trapObject.isActive]];
        [trapEntity setAlert:[NSNumber numberWithInt:trapObject.isAlert]];
        [trapEntity setAlarmDistance:[NSNumber numberWithInt:trapObject.alarmDistance]];
        [trapEntity setRoadNumber:[NSNumber numberWithInt:trapObject.roadNumber]];
        [trapEntity setPolys:[NSNumber numberWithInt:trapObject.polygons]];
        [trapEntity setEnter_to_area:[NSNumber numberWithInt:trapObject.getTrapEnterToArea]];

        // Double
        [trapEntity setLat:[NSNumber numberWithDouble:trapObject.getTrapLat]];
        [trapEntity setLon:[NSNumber numberWithDouble:trapObject.getTrapLon]];
        [trapEntity setClose_point_lat:[NSNumber numberWithDouble:trapObject.getTrapClosePointLat]];
        [trapEntity setClose_point_lon:[NSNumber numberWithDouble:trapObject.getTrapClosePointLon]];

        // NSString
        [trapEntity setLastTrapAlarm:[NSString stringWithFormat:@"%li", trapObject.getTrapLastAlarm]];
        [trapEntity setPoly0:trapObject.getTrapPolygonA];
        [trapEntity setPoly1: trapObject.getTrapPolygonB];
        [trapEntity setPoly2: trapObject.getTrapPolygonC];
        [trapEntity setPolygonAzimut1: trapObject.getTrapPolygonAzimuthA];
        [trapEntity setPolygonAzimut2: trapObject.getTrapPolygonAzimuthB];
        [trapEntity setPolygonAzimut3: trapObject.getTrapPolygonAzimuthC];
        [trapEntity setDesc: trapObject.getTrapDesc];
        // etc. for all properties ...

        error = nil;
        if (![appDelegate.managedObjectContext save:&error])
        {
            NSLog(@"%s error: %@", __PRETTY_FUNCTION__, error.localizedDescription);
        }
    }
}
更新-1: 我记录这些对象,并得到以下结果(当我将它们添加到核心数据时):

“(实体:CoreDataTrap;id:0x1477d510;数据:)”,
“(实体:CoreDataTrap;id:0x1477d520;数据:)”,
“(实体:CoreDataTrap;id:0x147cd410;数据:)”,
“(实体:CoreDataTrap;id:0x147cd420;数据:)”,
“(实体:CoreDataTrap;id:0x147cd430;数据:)”,
“(实体:CoreDataTrap;id:0x147cd440;数据:)”,
“(实体:CoreDataTrap;id:0x147cd450;数据:)”,
“(实体:CoreDataTrap;id:0x147cd460;数据:)”,
“(实体:CoreDataTrap;id:0x147cd470;数据:)”,
“(实体:CoreDataTrap;id:0x147cd480;数据:)”
我还记录了它们的值,这似乎是正确的值


但是,它没有更新。

您如何知道数据不在SQLite中?您正在查看文件还是没有在屏幕上看到数据。有两个不同的潜在问题

如果您正在查看文件,并且您使用的是iOS 7,那么您可能正在查看日志记录,这是您困惑的根源。日志模式已在iOS7中打开,将导致更新在辅助文件中保留一段时间。这将使您看起来数据不在SQLite文件中,因为它们尚未从日志文件移动到SQLite文件。在这种情况下,一切都很好

如果您正在查找显示在视图中的数据,则可能是视图代码出错。发布该视图代码将有助于对其进行诊断

我怀疑您正在查看SQLite文件。如果我错了,请纠正我

顺便说一句,这是:

[appDelegate.managedObjectContext save:&error];

if (error != nil) {
  NSLog(@"enableORdisableAlertInDatabase Error: %@", error.localizedDescription);
}
是检查此错误的错误方法<代码>-保存:返回一个布尔值,如果出现错误,应参考该布尔值:

if ([[appDelegate managedObjectContext] save:&error] == NO) {
  NSLog(@"Error saving: %@\n%@", [error localizedDescription], [error userInfo]);
}

您如何知道数据不在SQLite中?您正在查看文件还是没有在屏幕上看到数据。有两个不同的潜在问题

如果您正在查看文件,并且您使用的是iOS 7,那么您可能正在查看日志记录,这是您困惑的根源。日志模式已在iOS7中打开,将导致更新在辅助文件中保留一段时间。这将使您看起来数据不在SQLite文件中,因为它们尚未从日志文件移动到SQLite文件。在这种情况下,一切都很好

如果您正在查找显示在视图中的数据,则可能是视图代码出错。发布该视图代码将有助于对其进行诊断

我怀疑您正在查看SQLite文件。如果我错了,请纠正我

顺便说一句,这是:

[appDelegate.managedObjectContext save:&error];

if (error != nil) {
  NSLog(@"enableORdisableAlertInDatabase Error: %@", error.localizedDescription);
}
是检查此错误的错误方法<代码>-保存:返回一个布尔值,如果出现错误,应参考该布尔值:

if ([[appDelegate managedObjectContext] save:&error] == NO) {
  NSLog(@"Error saving: %@\n%@", [error localizedDescription], [error userInfo]);
}

使用最新版本的Base或SQLite Professional检查您的数据库,您会没事的。

使用最新版本的Base或SQLite Professional检查您的数据库,您会没事的。

您确定要将对象插入到对象图中吗?如果是这样,请在创建对象的地方张贴代码。在尝试保存之前,您正在检查上下文是否有任何更改,因此,如果没有更改,则不会执行保存(因此不会显示错误)。我在第一次添加代码时添加了代码。是否确实要将对象插入到对象图中?如果是这样,请在创建对象的地方张贴代码。在尝试保存之前,您正在检查上下文是否有任何更改,因此如果没有更改,则不会执行保存(因此不会显示错误)。我在第一次添加代码时添加了代码。好的,我如何查看sqlite文件?我的代码运行正常,没有错误,但我仍然希望检查sqlite文件。当它有更多数据时,您可以对其进行示例。日志文件最终将被消耗到SQLite文件中。另一个选择是抽真空SQLite文件,这将迫使它使用这些文件。我如何抽真空SQLite文件?当我提取手机上保存的应用程序的所有文件时,我确实有SQLite文件,但是那些关于核心数据的文件是空的,有什么想法吗?同样,它们是空的,因为数据在日志文件中。如果您在谷歌上搜索“vacuum SQLite”,您会发现在命令行上打开文件(使用SQLite CLI应用程序)并输入
vacuum
将导致数据库重建、日志文件被使用,您将看到数据。或者您可以只查看应用程序中的数据,并将实现细节留给核心数据。好的,我如何查看sqlite文件?我的代码运行正常,没有错误,但我仍然希望检查sqlite文件。当它有更多数据时,您可以对其进行示例。日志文件最终将被消耗到SQLite文件中。另一个选择是抽真空SQLite文件,这将迫使它使用这些文件。我如何抽真空SQLite文件?当我提取手机上保存的应用程序的所有文件时,我确实有SQLite文件,但是那些关于核心数据的文件是空的,有什么想法吗?同样,它们是空的,因为数据在日志文件中。如果您在谷歌上搜索“vacuum SQLite”,您会发现在命令行上打开文件(使用SQLite CLI应用程序)并输入
vacuum
将导致数据库重建、日志文件被使用,您将看到数据。或者,您可以只查看应用程序中的数据,并将实现细节留给核心数据。a)这只是一种意见-有其他应用程序读取SQLite文件b)更重要的是,问题的原因是日志记录,而不是无法读取文件。a)这是ju