static int row=0;

static const NSString *kStoryboardName = @"LRCoreDataViewController";

static const NSString *kIdentifier = @"LRCoreDataViewController";



@interface LRCoreDataViewControllerCellInfo : NSObject

@property (nonatomic,strong) NSString *name;

@property (nonatomic,strong) NSString *city;

@property (nonatomic,strong) NSString *state;

@end

@implementation LRCoreDataViewControllerCellInfo

@end

typedef LRCoreDataViewControllerCellInfo CellInfo_t;



@interface LRCoreDataViewController ()<LRAlertViewManagerDelegate,UITableViewDataSource,UITableViewDelegate>

{

    NSManagedObjectContext *_context;

}

@property (strong, nonatomic) IBOutlet UITableView *myTableView;

@property (nonatomic,strong) NSMutableArray *cellInfoArray;

@end



@implementation LRCoreDataViewController

@synthesize failedBankInfos;

@synthesize managedObjectContext;

+(instancetype)createViewController:(id)createArgs{

    UIStoryboard *storyboard = [UIStoryboard storyboardWithName:(NSString *)kStoryboardName bundle:nil];

    LRCoreDataViewController *vc = [storyboard instantiateViewControllerWithIdentifier:(NSString *)kIdentifier];

    return vc;

}

- (void)viewDidLoad {

    [super viewDidLoad];

    self.view.backgroundColor=[UIColor cyanColor];

    [self initCoreData];

    [self initRightItem];

    [self initTableView];

    [self setExtraCellLineHidden:self.myTableView];

    //[self openDataBase];

    self.myDelegate = (AppDelegate *)[[UIApplication sharedApplication] delegate];

}

- (void)openDataBase{

    NSManagedObjectModel *model=[NSManagedObjectModel mergedModelFromBundles:nil];

    NSPersistentStoreCoordinator *coodinator=[[NSPersistentStoreCoordinator alloc]initWithManagedObjectModel:model];

    NSString *path = [NSHomeDirectory() stringByAppendingPathComponent:@"Documents/mydatabase.db"];

    NSError *error=nil;

    [coodinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:[NSURL fileURLWithPath:path] options:nil error:&error];

    if (error) {

        NSLog(@"打开数据库失败");

    }else{

        NSLog(@"创建数据库成功");

        _context=[[NSManagedObjectContext alloc]init];

        _context.persistentStoreCoordinator=coodinator;

    }

}

- (void)setExtraCellLineHidden: (UITableView *)tableView{

    UIView *view =[ [UIView alloc]init];

    view.backgroundColor = [UIColor clearColor];

    [tableView setTableFooterView:view];

    [tableView setTableHeaderView:view];

}

- (void)initTableView{

    self.myTableView.delegate=self;

    self.myTableView.dataSource=self;

}

- (void)initRightItem{

    UIButton *rightBtn = [[UIButton alloc]init];

    [rightBtn setFrame:CGRectMake(0, 0, 39, 36)];

    [rightBtn setImage:[UIImage imageNamed:@"addData"] forState:UIControlStateNormal];

    rightBtn.showsTouchWhenHighlighted = YES;

    [rightBtn addTarget:self action:@selector(addData) forControlEvents:UIControlEventTouchUpInside];

    UIBarButtonItem *buttonItem = [[UIBarButtonItem alloc] initWithCustomView:rightBtn];

    self.navigationItem.rightBarButtonItem = buttonItem;

}

#pragma mark - 向数据库中添加数据,并显示在当前界面

- (void)addData{

    LRAlertViewManager *manager=[LRAlertViewManager sharedAlertViewManager];

    manager.delegate=self;

    [manager showAlertView];

}

- (void)clickButton:(int)tag{

    if (tag==99) {

        NSError *error;

        //创建一个指向数据库的指针。管理对象,上下文。持久性存储模型对象

        NSManagedObjectContext *context=[self managedObjectContext];

        NSManagedObject *BankInfo=[NSEntityDescription insertNewObjectForEntityForName:@"BankInfo" inManagedObjectContext:context];

        [BankInfo    setValue:@"姓名" forKey:@"name"];

        [BankInfo    setValue:@"城市" forKey:@"city"];

        [BankInfo    setValue:@"状态" forKey:@"sta"];

        [BankInfo    setValue:[NSNumber numberWithInt:row] forKey:@"row"];

        NSManagedObject    *bankDetails=[NSEntityDescription insertNewObjectForEntityForName:@"BankDetails" inManagedObjectContext:context];

        [bankDetails setValue:[NSDate date] forKey:@"hh"];

        [bankDetails setValue:[NSDate date] forKey:@"mm"];

        [bankDetails setValue:[NSNumber numberWithInt:12345] forKey:@"zip"];

        [bankDetails setValue:BankInfo forKey:@"info"];

        [bankDetails    setValue:bankDetails forKey:@"details"];

        if (![context save:&error]) {

            NSLog(@"Whoops, could not save:%@",[error localizedDescription]);

        }

        NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];

        NSEntityDescription *entity = [NSEntityDescription entityForName:@"FailedBankInfo" inManagedObjectContext:context];

        [fetchRequest setEntity:entity];

        NSArray *fetchedObjects = [context executeFetchRequest:fetchRequest error:&error];

        for (FailedBankInfo *info in fetchedObjects) {

            NSLog(@"row: %d", info.row);

            FailedBankDetails *details = info.details;

            NSLog(@"Zip: %@", details.zip);

        }

        NSFetchRequest *fetchRequest2 = [[NSFetchRequest alloc] init];

        NSEntityDescription *entity2 = [NSEntityDescription entityForName:@"FailedBankInfo" inManagedObjectContext:managedObjectContext];

        [fetchRequest2 setEntity:entity2];

        NSError *error2;

        self.failedBankInfos = [managedObjectContext executeFetchRequest:fetchRequest2 error:&error2];

        [self.myTableView reloadData];

        row++;

    }else if (tag==100){

        NSManagedObjectContext *context = [self managedObjectContext];

        NSEntityDescription *description = [NSEntityDescription entityForName:@"FailedBankInfo" inManagedObjectContext:context];

        NSFetchRequest *request = [[NSFetchRequest alloc] init];

        [request setIncludesPropertyValues:NO];

        [request setEntity:description];

        NSError *error = nil;

        NSArray *datas = [context executeFetchRequest:request error:&error];

        if (!error && datas && [datas count]){

            for (NSManagedObject *obj in datas){

                [context deleteObject:obj];

            }

            if (![context save:&error]){

                NSLog(@"error:%@",error);

            }

        }

        NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];

        NSEntityDescription *entity = [NSEntityDescription entityForName:@"FailedBankInfo" inManagedObjectContext:managedObjectContext];

        [fetchRequest setEntity:entity];

        NSError *error2;

        self.failedBankInfos = [managedObjectContext executeFetchRequest:fetchRequest error:&error2];

        [self.myTableView reloadData];

    }

}

#pragma mark -初始化 NSArray存数据

- (void)initCoreData{

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];

    NSEntityDescription *entity = [NSEntityDescription entityForName:@"FailedBankInfo" inManagedObjectContext:managedObjectContext];

    [fetchRequest setEntity:entity];

    NSError *error;

    self.failedBankInfos = [managedObjectContext executeFetchRequest:fetchRequest error:&error];

    self.title = @"CoreData";

}

#pragma mark - Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {

    return 1;

}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

    return failedBankInfos.count;

}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    static NSString *CellIdentifier = @"Cell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];

    

    if (!cell) {

        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];

    }

    FailedBankInfo *info = [failedBankInfos objectAtIndex:indexPath.row];

    cell.textLabel.text = info.name;

    cell.detailTextLabel.text = [NSString stringWithFormat:@"%@, %@",info.city, info.state];

    UILabel *deleteLabel=[[UILabel alloc]initWithFrame:CGRectMake([UIScreen mainScreen].bounds.size.width-200, 5, 200, 40)];

    deleteLabel.text=@"向左滑动删除CoreData数据";

    [cell.contentView addSubview:deleteLabel];

    return cell;

}

-(UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath{

    return UITableViewCellEditingStyleDelete;

}

-(NSString *)tableView:(UITableView *)tableView titleForDeleteConfirmationButtonForRowAtIndexPath:(NSIndexPath *)indexPath{

    return @"删除";

}

-(void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath{

    NSManagedObjectContext *context = [self managedObjectContext];

    NSEntityDescription *description = [NSEntityDescription entityForName:@"FailedBankInfo" inManagedObjectContext:context];

    NSFetchRequest *request = [[NSFetchRequest alloc] init];

    [request setIncludesPropertyValues:NO];

    [request setEntity:description];

    NSError *error = nil;

    NSArray *datas = [context executeFetchRequest:request error:&error];

    if (!error && datas && [datas count]){

        [context deleteObject:datas[indexPath.row]];

        if (![context save:&error]){

            NSLog(@"error:%@",error);

        }

    }

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];

    NSEntityDescription *entity = [NSEntityDescription entityForName:@"FailedBankInfo" inManagedObjectContext:managedObjectContext];

    [fetchRequest setEntity:entity];

    NSError *error2;

    self.failedBankInfos = [managedObjectContext executeFetchRequest:fetchRequest error:&error2];

    [self.myTableView deleteRowsAtIndexPaths:[NSMutableArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];

    [self.myTableView reloadData];

}

iOS coreData的更多相关文章

  1. iOS CoreData技术学习资源汇总

    一.CoreData学习指引 1. 苹果官方:Core Data Programming Guide 什么是CoreData? 创建托管对象模型 初始化Core Data堆栈 提取对象 创建和修改自定 ...

  2. IOS CoreData 多表查询demo解析

    在IOS CoreData中,多表查询上相对来说,没有SQL直观,但CoreData的功能还是可以完成相关操作的. 下面使用CoreData进行关系数据库的表与表之间的关系演示.生成CoreData和 ...

  3. iOS CoreData (一) 增删改查

    代码地址如下:http://www.demodashi.com/demo/11041.html Core Data是iOS5之后才出现的一个框架,本质上是对SQLite的一个封装,它提供了对象-关系映 ...

  4. iOS CoreData (二) 版本升级和数据库迁移

    前言:最近ChinaDaily项目需要迭代一个新版本,在这个版本中CoreData数据库模型上有新增表.实体字段的增加,那么在用户覆盖安装程序时就必须要进行CoreData数据库的版本升级和旧数据迁移 ...

  5. IOS CoreData 多表查询(下)

    http://blog.csdn.net/fengsh998/article/details/8123392 在iOS CoreData中,多表查询上相对来说,没有SQL直观,但COREDATA的功能 ...

  6. iOS CoreData 介绍和使用(以及一些注意事项)

    iOS CoreData介绍和使用(以及一些注意事项) 最近花了一点时间整理了一下CoreData,对于经常使用SQLite的我来说,用这个真的有点用不惯,个人觉得实在是没发现什么亮点,不喜勿喷啊.不 ...

  7. iOS CoreData介绍和使用(以及一些注意事项)

    iOS CoreData介绍和使用(以及一些注意事项) 最近花了一点时间整理了一下CoreData,对于经常使用SQLite的我来说,用这个真的有点用不惯,个人觉得实在是没发现什么亮点,不喜勿喷啊.不 ...

  8. iOS - CoreData 数据库存储

    1.CoreData 数据库 CoreData 是 iOS SDK 里的一个很强大的框架,允许程序员以面向对象的方式储存和管理数据.使用 CoreData 框架,程序员可以很轻松有效地通过面向对象的接 ...

  9. iOS coreData问题

    iOS常见错误-CoreData: Cannot load NSManagedObjectModel.nil is an illegal URL parameter
这是因为在工程中CoreData的 ...

  10. ios Coredata 的 rollback undo 等事物处理函数

    首先说明 ios 中 NSManagedObjectContext 默认的 undoManager是nil的,就是说 undo 和 redo 都是没用的. 但是 rollback函数和reset函数是 ...

随机推荐

  1. Python学习入门基础教程(learning Python)--3.3.1 Python下的布尔表达式

    简单的说就是if要判断condition是真是假,Python和C语言一样非0即真,所以如果if的condition是布尔表达式我们可以用True或者非0数(不可是浮点数)表示真,用False或者0表 ...

  2. net Mvc模块化开发

    Asp.net Mvc模块化开发之“部分版本部分模块更新(上线)” 项目开发从来就不是一个简单的问题.更难的问题是维护其他人开发的项目,并且要修改bug.如果原系统有重大问题还需要重构. 怎么重构系统 ...

  3. 基于opencv在摄像头ubuntu根据视频获取

     基于opencv在摄像头ubuntu根据视频获取 1  工具 原料 平台 :UBUNTU12.04 安装库  Opencv-2.3 2  安装编译执行步骤 安装编译opencv-2.3  參考h ...

  4. 当执行游戏0xc000007b错误的解决方法

    如图,这个错误使无数玩家烦恼. 出现这个错误,可能是硬件的问题,也可能是软件的问题.可是,因为硬件引起该问题的概率非常小,而且除了更换硬件之外没有更好的解决方法,因此本文将具体介绍怎样通过软件解决此问 ...

  5. 《Linux内核设计与实现》的地址空间读书笔记的过程

    1.核心区域进程包括各种内存对象 种内存对象,比方: 1.可运行文件代码能够包括各种内存映射,称为代码段(text section). 2.可运行文件的已初始化全局变量的内存映射,称为数据段(data ...

  6. Ctrl+Alt+T 文档大纲

  7. [置顶] ios 一个不错的图片浏览分享框架demo

    demo功能:一个不错的图片浏览分享框架demo.iphone6.1 测试通过.可以浏览图片,保存,微博分享到新浪,腾讯,网易,人人等. 注:(由于各个微博的接口有时候会有调整,不一定能分享成功.只看 ...

  8. 谷歌技术面试要点(Google面试)(14年5月20日交大专场)

    技术面试的主题 1.简要自我介绍: 姓名.学校.专业 做过的项目与实习 个人主要成就 2.技术评估: 构建与开发算法 编程 计算机基础知识 数据结构 现实世界问题解决能力 设计问题(主要针对博士生) ...

  9. DV工作流

  10. Spring的文件上传

    Spring在发现包括multipart的请求后,会使用MultipartResolver的实现bean处理文件上传操作,现有採用Servlet3的 org.springframework.web.m ...