转载说明(谢谢)
http://blog.csdn.net/a21064346/article/details/8082428
点击打开链接
今天很累,找了一天的coredata对不同数据类型的 attribute的处理,但是还是没有找到一个合理的解决方案。
下面就来和大家分享一下今天的收获。
对于使用过coreData的朋友来说,一定碰到过 type 的类型中没有自己想要得到的那一种。
比如NSArray,NSDictionary,NSValue等等。
比如CGRect,CGImage,UIColor,UIFont等等
那么下面我将介绍,我对这些东西处理有4种方法可以落实。
第一种方法:以前写过一个blog,就是第一种,大家可以去看看,这里省略.
http://blog.csdn.net/a21064346/article/details/7792074
第二种:将attribute的type设置成Transformable格式。使用时装载的数据格式得遵循<NSCoding>
NSAttributeType type = [self typeForEditedAttribute]; switch( type ) { case NSDateAttributeType: valueFromView = self.datePicker.date; break; case NSStringAttributeType: if( [self.fieldKeyTester shouldUseTextViewForKey: self.editedFieldKey inEntity: self.editedObject.entity.name] ) { valueFromView = self.textView.text; } else { valueFromView = self.textField.text; } break; case NSInteger16AttributeType: case NSInteger32AttributeType: case NSInteger64AttributeType: valueFromView = [NSNumber numberWithInteger: [self.textField.text integerValue]]; break; case NSDecimalAttributeType: case NSDoubleAttributeType: case NSFloatAttributeType: valueFromView = [NSNumber numberWithDouble: [self.textField.text doubleValue]]; break; case NSBooleanAttributeType: valueFromView = [NSNumber numberWithBool: self.switchControl.isOn]; break; case NSObjectIDAttributeType: case NSTransformableAttributeType://这里就可以来进行一个归档,然后通过coredata进行存储了。反向操作的时候,也是类似的。
//根据自己的code来写判定条件就好了。 case NSBinaryDataAttributeType: case NSUndefinedAttributeType: NSLog( @"Don't know how to handle attribute type: %d in %s", type, __func__ ); break; default: NSLog( @"Unrecognized attribute type: %d in %s", type, __func__ ); break; }
其实,看完第一种方法的人,运用过,就可以发掘,这两种东西不是感觉一回事吗?答案是否定的。举个比喻来说:第一种方法是 东西还没吃到肚子里,就开始做归档操作转化为NSData的形式,用的时候再反向操作。第二种方法,虽然也是要去进行类似的处理,但是它是在配置搭建entities(表)的时候(还没倒入数据),就已经弄成这样了。他们一个作用于coredata外,一个是在内。
不过,它们的本质都是 归档,用NSData的格式将数据装起来,用的时候再反向操作。
再介绍第三种方法之前,我想先对前两种方法做一个总结
优点:几乎所有需要存储的数据 都可以通过前两种方法得到解决,方便,将数据得以保存。
缺点:不能通过 qury查询 或者 fetchResult 来进行过滤。(往往这是致命的缺点)
第三种方法,也是本人即将使用的方法(实在是前两种解决不了,因为我需要qury 或者说过滤,而且也没找到好的方法,如果有人能指点一二感激不尽)
将需要的数据(一般来说是需要你能过滤的string的数组),一段一段的写进一个string中,通过一个特殊的标志符号来进行隔断。
查询的时候 例如 :phoneNumbers中的一个,而一个人有多个phoneNumber,并且有不同的标签。e.g : work 123456;home 0987654;iPhone 778899;
那么我这样自行 组成的string 好处就能发挥出来。
但是,如果是查询 url的话,可能会比较麻烦,因为几乎你找不到 起到划分作用的 字符来拆 string(幸好我没碰到哈哈),而你又需要去过滤去查询,而且又是一个数组或字典的数据对象。
第四种方法,对特殊的attribute 单独建立一个 entity
因为这快不算熟悉,单独的entity需要 relation,和其他entity进行连接