我正在尝试将数组添加到iPhone上的SQLite数据库中。问题是,我不知道用户想要使用多少个数组对象。它可能是1,它可能是10.如果我在SQLite表中分配了10个字段,那么如果用户要使用一个字段就会有9个字段,并且它会将上限设置为10个条目。
因此,我想到使用单个VARCHAR类型字段,并在每个对象之间添加特殊字符的数组的每个对象。这将如何表现明智?有更好的想法吗?
答案 0 :(得分:3)
我的猜测是使用NSCoder框架。由于NSArray符合NSCoding协议,因此序列化已经完成:
NSMutableData *data = [[NSMutableData alloc] init];
NSKeyedArchiver *archiver = [[NSKeyedArchiver alloc] initForWritingWithMutableData:data];
[archiver encodeObject:myArray forKey:myArchiveKey];
[archiver finishEncoding];
[archiver release];
// write here data object to a BLOB field of your SQLite db
解码将非常相似
答案 1 :(得分:0)
您可以将它们保存为OBJECT列。
答案 2 :(得分:0)
您可以将数组条目存储为行。
答案 3 :(得分:0)
您可以将数组保存为json对象格式,同时检索将json对象转换为数组。