gpt4 book ai didi

ios - 获取获取请求后无法更新 CoreData 模型

转载 作者:行者123 更新时间:2023-11-29 12:55:58 25 4
gpt4 key购买 nike

我的应用程序是这样设置的,我有两个 View Controller 来 self 的 RootViewController - 一个带有两个按钮的简单主选择页面。顶部按钮将我发送到 ViewController 1,我在那里拍照并在关于照片的 6 个文本字段中插入数据。然后我点击保存按钮,将这些实体保存到我的 ManagedObjectContext 中的 ManagedObjectModel TargetData。主页上的第二个按钮指向一个 TableVIewController,我在其中调用了 NSFetchedResults 之类的东西来更新 TableView。

它工作得很好......至少在我运行 TableViewController 一次之前是这样。在显示 TableViewController 之前,我可以添加任意数量的带有文本数据的照片,此时,在离开页面时,TableViewController 将只显示它在我第一次打开页面时加载的对象,而不显示之后添加的任何项目.我做了一些搜索,发现在第一次加载 TableVIew 之后,fetchResults 只看到它在第一次加载时看到的许多实体。例如,如果我启动应用程序,添加 5 张带文字的照片,然后运行 ​​TableViewController,我会看到 5 个项目正确显示。我可以返回到主页,然后添加另一张带有文本的照片,但如果我返回到 TableVIewController,我将只能看到我在打开 TableViewController 之前添加的 5 张照片。

在 TableViewController 的类中,我设置了 TableViewController.m 文件中的所有常规方法。

完全没有头绪。帮助!

编辑:这是我的一些代码

来自:会保存数据的ViewController.m

    - (IBAction)saveTarget:(id)sender {
//Only save if there is an image other than the stock photo
if (self.image != [UIImage imageNamed:@"Photo-Video-Slr-camera-icon"]) {

//Grab the main ManagedObjectContext from the AppDelegate
sTCAppDelegate *appDelegate =[[UIApplication sharedApplication] delegate];
NSManagedObjectContext *context =[appDelegate managedObjectContext];
//Get the Target model from CoreData
[self setTarget:[NSEntityDescription insertNewObjectForEntityForName:@"TargetData" inManagedObjectContext:context]];

//Set the properties of the TargetData model
self.target.weaponData = self.weaponData.text;
self.target.bulletType = self.bulletType.text;
self.target.stanceType = self.stanceType.text;
self.target.distanceData = self.distanceData.text;
self.target.targetNotes = self.targetNotes.text;
self.target.sightType = self.sightType.text;
self.target.scoreData = [NSNumber numberWithInt:[self.scoreData.text intValue]];

//Set image to smaller size for storage
UIImage *image = [self resizeImage:self.image toWidth:50 andHeight:50];
//Save as PNG NSData for compression
self.target.targetImage = UIImagePNGRepresentation(image);

//Set a date property to use for organizing by most recently saved
self.target.timeStamp = [NSDate date];

//Save to context
NSError *error = nil;
if ( ![context save:&error] ){
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}

//Jump back to main page
[self.navigationController popToRootViewControllerAnimated:YES];

//set images back to nil for next time AddTarget is opened
image = nil;
self.image = nil;
NSLog(@"Data Saved");
}
//Return alert if user has not entered a photo
else{
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"We're Sorry!" message:@"You must enter at least a photo to save target data." delegate:nil cancelButtonTitle:@"Okay" otherButtonTitles:nil];
[alert show];
}
}

来自:显示数据的TableViewController.m

#pragma mark - Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
// Return the number of sections.
NSLog(@"number of sections:%lu",(unsigned long)[[self.fetchedResultsController sections] count]);
return [[self.fetchedResultsController sections] count];
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
id <NSFetchedResultsSectionInfo> sectionInfo = [[self.fetchedResultsController sections] objectAtIndex:section];
NSLog(@"%lu", [sectionInfo numberOfObjects]);
return [sectionInfo numberOfObjects];
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *CellIdentifier = @"Cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];

NSLog(@"Ran Cell Configure");
[self configureCell:cell atIndexPath:indexPath];
// Configure the cell...

return cell;
}
-(void)configureCell:(UITableViewCell *)cell atIndexPath:(NSIndexPath *)indexPath{

TargetData *target = [self.fetchedResultsController objectAtIndexPath:indexPath];
UIImage *image = [UIImage imageWithData:target.targetImage];
cell.imageView.image = image;
cell.textLabel.text = [NSString stringWithFormat:@"%@", target.scoreData];
cell.detailTextLabel.text = target.weaponData;
}

#pragma mark- FetchedResultsControllerDelegate Methods

- (NSFetchedResultsController *)fetchedResultsController {
if (_fetchedResultsController != nil)
{
return _fetchedResultsController;
}
sTCAppDelegate *appDelegate =[[UIApplication sharedApplication] delegate];
NSManagedObjectContext *context =[appDelegate managedObjectContext];

NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"TargetData" inManagedObjectContext:context];

[fetchRequest setEntity:entity];
[fetchRequest setFetchBatchSize:0];

NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"timeStamp" ascending:NO];
NSArray *sortDescriptors = [NSArray arrayWithObjects:sortDescriptor, nil];

[fetchRequest setSortDescriptors:sortDescriptors];

NSFetchedResultsController *aFetchedRequestsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:context sectionNameKeyPath:nil cacheName:@"Master"];
aFetchedRequestsController.delegate = self;
self.fetchedResultsController = aFetchedRequestsController;

NSError *error = nil;

if (![self.fetchedResultsController performFetch:&error])
{
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}

return _fetchedResultsController;
}

- (void)controllerWillChangeContent:(NSFetchedResultsController *)controller {
[self.tableView beginUpdates];
}


- (void)controller:(NSFetchedResultsController *)controller didChangeSection:(id <NSFetchedResultsSectionInfo>)sectionInfo
atIndex:(NSUInteger)sectionIndex forChangeType:(NSFetchedResultsChangeType)type {

switch(type) {
case NSFetchedResultsChangeInsert:
[self.tableView insertSections:[NSIndexSet indexSetWithIndex:sectionIndex]
withRowAnimation:UITableViewRowAnimationFade];
break;

case NSFetchedResultsChangeDelete:
[self.tableView deleteSections:[NSIndexSet indexSetWithIndex:sectionIndex]
withRowAnimation:UITableViewRowAnimationFade];
break;
}
}


- (void)controller:(NSFetchedResultsController *)controller didChangeObject:(id)anObject
atIndexPath:(NSIndexPath *)indexPath forChangeType:(NSFetchedResultsChangeType)type
newIndexPath:(NSIndexPath *)newIndexPath {

UITableView *tableView = self.tableView;

switch(type) {

case NSFetchedResultsChangeInsert:
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath]
withRowAnimation:UITableViewRowAnimationFade];
break;

case NSFetchedResultsChangeDelete:
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath]
withRowAnimation:UITableViewRowAnimationFade];
break;

case NSFetchedResultsChangeUpdate:
[self configureCell:[tableView cellForRowAtIndexPath:indexPath]
atIndexPath:indexPath];
break;

case NSFetchedResultsChangeMove:
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath]
withRowAnimation:UITableViewRowAnimationFade];
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath]
withRowAnimation:UITableViewRowAnimationFade];
break;
}
}


- (void)controllerDidChangeContent:(NSFetchedResultsController *)controller {
[self.tableView endUpdates];
}

- (IBAction)mainMenu:(id)sender {
[self.navigationController popToRootViewControllerAnimated:YES];
}

是的,我正在使用 TableViewController 实现中的方法。

编辑 2

我通常在我的实际 iPhone 上运行我的应用程序来测试它,因为这样我就可以在我的设备中使用相机。为了查看控制台可能对我的问题说些什么,我向模拟器添加了一些图像并在模拟器上运行它。这次,在添加一张带文字的照片后,打开 TableViewController,然后添加另一张照片,再次尝试打开 TableViewController 后,我收到了一个巨大的崩溃错误报告。

这是错误的终止部分:

2014-01-13 13:09:38.759 Target Tracker[25124:70b] *** 由于未捕获的异常“NSInternalInconsistencyException”而终止应用程序,原因:“CoreData: fatal error :部分信息的持久缓存不匹配当前配置。你在没有禁用缓存或使用 +deleteCacheWithName 的情况下非法改变了 NSFetchedResultsController 的获取请求、它的谓词或它的排序描述符:'

知道这是什么意思吗?

已解决

问题是我在运行 TableViewController 时缓存了 FetchResults。当我向模型添加另一个实体并尝试返回新的 fetchResult 时,它与返回严重 CoreData 错误的缓存版本不匹配。我没有将其视为错误,因为我最初不是在模拟器中运行该应用程序,而是在我的实际设备上运行。一旦我在模拟器中运行它,我就能够看到这个错误。

简而言之——我需要在初始化 NSFetchedResultsController 时将“cacheName”设置为 nil

NSFetchedResultsController *aFetchedRequestsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:context sectionNameKeyPath:nil cacheName:nil];

有关更多信息,请参阅此帖子:NSFetchedResultsController crashing on performFetch: when using a cache

最佳答案

问题是我在运行 TableViewController 时缓存了 FetchResults。当我向模型添加另一个实体并尝试返回新的 fetchResult 时,它与返回严重 CoreData 错误的缓存版本不匹配。我没有将其视为错误,因为我最初不是在模拟器中运行该应用程序,而是在我的实际设备上运行。一旦我在模拟器中运行它,我就能够看到这个错误。

简而言之——我需要在初始化 NSFetchedResultsController 时将“cacheName”设置为 nil

NSFetchedResultsController *aFetchedRequestsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:context sectionNameKeyPath:nil cacheName:nil];

有关更多信息,请参阅此帖子:NSFetchedResultsController crashing on performFetch: when using a cache

关于ios - 获取获取请求后无法更新 CoreData 模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21098359/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com