CoreData数据验证失败仍然插入context的解决(二)
2017-01-06 14:13
351 查看
在之前的一篇 博文 里我们给出了两种解决办法:
第一种方法预先不指定context,在实际插入时在指定
第二种方法是在验证失败时重置context中的内容
其实CoreData自身还提供了另一种方法,就是context子对象.
对于一个context来说,默认其parent属性指向永久存储协调器(NSPersistentStoreCoordinator),不过我们可以让其指向另一个context,这样做的好处是sub context的所有修改要想应用到底层数据库中必须起parent也进行save才可以.如果其parent context没有进行save,则内容会被全部丢弃,不会对底层造成任何影响.下面我们来看看如何利用这个特性来解决题目中的问题.
首先是创建sub context:
然后在创建新托管对象时使用childCtx:
在最终需要保存的时候调用如下代码:
注意以上代码的do块中需要save两次,第一次是childCtx的保存,后一次是parent context的保存.保存是递进型的,childCtx保存到parent Context中,而parent Ctx最终保存到底层数据库中.省略其中任何一个save,App表现的都不正确.而且如果在do块中出错,则childCtx的修改直接被丢弃,从而不会影响parent Ctx的内容,更别说底层数据库了 ;)
第一种方法预先不指定context,在实际插入时在指定
第二种方法是在验证失败时重置context中的内容
其实CoreData自身还提供了另一种方法,就是context子对象.
对于一个context来说,默认其parent属性指向永久存储协调器(NSPersistentStoreCoordinator),不过我们可以让其指向另一个context,这样做的好处是sub context的所有修改要想应用到底层数据库中必须起parent也进行save才可以.如果其parent context没有进行save,则内容会被全部丢弃,不会对底层造成任何影响.下面我们来看看如何利用这个特性来解决题目中的问题.
首先是创建sub context:
let childCtx = NSManagedObjectContext(concurrencyType: .mainQueueConcurrencyType) childCtx.parent = containerVC.managedObjectContext
然后在创建新托管对象时使用childCtx:
if let entity = NSEntityDescription.entity(forEntityName: "KsMain", in: childCtx){ let ks = KsMain(entity:entity,insertInto:childCtx) //fill ks's properties
在最终需要保存的时候调用如下代码:
func insertKsMain(ks:KsMain){ do{ try ks.validateForInsert() try? ks.managedObjectContext?.save() saveContext() }catch{ print(error.localizedDescription) } }
注意以上代码的do块中需要save两次,第一次是childCtx的保存,后一次是parent context的保存.保存是递进型的,childCtx保存到parent Context中,而parent Ctx最终保存到底层数据库中.省略其中任何一个save,App表现的都不正确.而且如果在do块中出错,则childCtx的修改直接被丢弃,从而不会影响parent Ctx的内容,更别说底层数据库了 ;)
相关文章推荐
- CoreData数据验证失败仍然插入context的解决(三)
- CoreData数据验证失败仍然插入context的解决(一)
- CoreData数据验证失败仍然插入context的解决(三)
- CoreData数据验证失败仍然插入context的解决(一)
- CoreData数据验证失败仍然插入context的解决(二)
- CoreData数据验证失败仍然插入context的解决(二)
- CoreData数据验证失败仍然插入context的解决(三)
- CoreData数据验证失败仍然插入context的解决(一)
- 跨服务器post数据失败:验证视图状态 MAC 失败。如果此应用程序由网络场或群集承载,请确保 <machineKey> 配置指定了相同的 validationKey 和验证算法。的解决办法
- 完美解决ListView中事件ItemCreated中使用ClientID导致插入数据失败
- MySql中插入中文数据提示Data too long for column X at row n的解决
- 解决使用Validform插件,datatype里用ajax验证数据是否已经存在时出现的问题
- Hibernate插入数据时报错Data truncation: Data too long for column 'name' at row 1 解决办法
- thinkphp 在数据库更新(save)的时候,如果字段没有被修改,会更新失败 和数据的自动验证,插入的时候可以自动验证,但更新的时候就不能验证了
- mysql max_allowed_packet自动重置为1024 ,数据插入失败问题解决
- flex中,用ArrayCollection作为DataGrid的dataProvider,想在ArrayCollection末尾插入数据的解决方法
- IOS CoreData 多表查询demo解析(二)--插入测试数据
- mvc EF 数据保存时,报错:”对一个或多个实体的验证失败……“之解决
- 解决 mysql [Data Too Long..]数据更新失败的异常
- CoreData实践(三)——插入数据并使用SQLite Professional查看