我已经在APPDelegate中实现了核心数据并创建了一个新类并从JSON和NSURLConnection获取数据完成了我正在使用快速枚举将数据存储到核心数据中它运行良好并在tableview中显示nsfetch请求但是问题是每次我启动应用程序时,它会一次又一次地将数据存储到sqlite文件中,为什么会发生这些方法?
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
self.customCellClass = [tableView dequeueReusableCellWithIdentifier:@"Cell"];
if (self.customCellClass == nil)
{
self.customCellClass = [[CellCustom alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"Cell"];
}
self.customCellClass.nameLabel.text = [_myArray[indexPath.row] name];// label
self.customCellClass.cityLabel.text = [_myArray[indexPath.row] regions]; // label
self.customCellClass.detailLabel.text = [_myArray[indexPath.row] summary]; //label
return self.customCellClass;
}
-(void)connectionDidFinishLoading:(NSURLConnection *)connection
{
arrayData = [NSJSONSerialization JSONObjectWithData:data options:0 error:nil];
NSManagedObjectContext *context = [appDelegate managedObjectContext];
appDelegate = [[UIApplication sharedApplication ]delegate];
context = [appDelegate managedObjectContext];
NSString * name ;
NSString * summary;
NSString * region;
for (NSDictionary * dic in arrayData) {
name = [dic objectForKey:@"name"];
summary = [dic objectForKey:@"summary"];
region = [dic objectForKey:@"region"];
Discount * d = [NSEntityDescription insertNewObjectForEntityForName:@"Discount" inManagedObjectContext:context];
d.name = name;
d.summary = summary;
d.regions = region;
}
NSError *error;
if (![context save:&error]) {
NSLog(@"Getting error while saving data");
}
else{
NSLog(@"Saved");
}
[listTableView reloadData];
}
并且appdelegate方法只是每个人提供的常见方法 有人给我解决方案
答案 0 :(得分:1)
因为当您启动应用程序时,您会再次下载并保存数据。请检查数据库中此类数据的可用性。 或者仅在首次启动时下载数据。
答案 1 :(得分:0)
添加此观察者并检查它是否在第一次启动时被调用。
NSManagedObjectContext *context = [appDelegate managedObjectContext];
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(dataDidSave)
name:NSManagedObjectContextDidSaveNotification
object:context];
-(void)dataDidSave
{
self.myArray = // get data from data base
[listTableView reloadData];
}