数据永久性存储

1.NSFileHandle

<注意>只能存入和读取字符串

2.Plist文件

<注意>只能存放7种类型的对象指针 ——开发中经常用于存放固定不变的内容 比如tabBar上的标题、图片等

3.NSUserDefaults

<注意>只能存放7种类型的对象指针 ——开发中经常用于存放固定不变的内容 比如tabBar上的标题、图片等
NSUserDefaults支持的数据类型有:NSNumber(NSInteger、float、double),NSString,NSDate,NSArray,NSDictionary,BOOL.
NSUserDefaults适合存储轻量级的本地数据,一些简单的数据(NSString类型的)例如密码,网址等,NSUserDefaults肯定是首选,但是如果我们自定义了一个对象,对象保存的是一些信息,这时候就不能直接存储到NSUserDefaults了
NSString * name = @"lucy";
NSString * passW = @"123";
//创建 在沙盒路径下 UI
NSUserDefaults * userD = [NSUserDefaults standardUserDefaults];
//第一次 在本机 登录的时候
[userD setObject:name forKey:@"name"];
[userD setObject:passW forKey:@"passW"];
//以前的时候 把数据 同步到本地的磁盘
[userD synchronize];
//演示第二次登录
NSUserDefaults * userS = [NSUserDefaults standardUserDefaults];
NSString * name = [userS objectForKey:@"name"];
NSString *passW = [userS objectForKey:@"passW"];

4.归档

<注意>能够存放任意类型的对象指针(对象指针所属的类必须遵守NSCoding协议 对象指针的成员变量所属的类也要遵守NSCoding协议)

5.数据库SQLite使用

//数据库存放的位置在沙盒路径
//数据库在使用之前必须处于打开状态
//数据库存放在沙盒路径下的Documents 数据库的后缀为.db 或.sqlite
//数据库中表格内的数据进行增删改查操作 有开源的第三方库FMDataBase
//使用第三方库对数据库进行操作需要导入框架libsqlite3.framwork
使用sql语句只能存放系统类的对象指针 数据库存放的位置在当前设备的沙盒路径下
数据库一般一个工程只创建一个
//存放本地图片 在数据库中的存放格式就是二进制
//存放网络图片、音频、视频 在数据库中的存放格式就是资源的地址
blob: 二进制对象
SQL语句
create table if not exists Student (ID integer primary key autoincrement,name varchar(256),age integer,birthDay date);
//表格创建成功以后 里面的字段不能添加也不能删除 否则数据修改失败
//<1>向表格插入数据
//[注意]插入的数据除了整型、浮点型以外的所有类型的数据全部需要用 ' '括起来
insert into Student(name,age,birthDay) values ('闽航',18,'1996-12-10');
insert into Student(name,age) values ('玲玲',18);
//查询
//<1>查询表格中所有数据信息
select * from Student;
insert to Student(name,age,birthDay) values ('张三',19,'1890-09-10');
//<2>查询几个字段的值
select name,age from Student;
//<3>按照某个条件查询
select * from Student where name = '闽航';
//<4>按照某个条件模糊查询
select * from Student where name like '%航%';
//<5>按照条件查询某个字段
select birthDay from Student where name = '闽航';
//<6>查询表格中对象的个数
select count(*) from Student;
//<7>查询某个字段的总和
select sum(age) from Student;
//<8>查询某个字段的平均值
select avg(age) from Student;
//修改
//<1>修改表格中所有字段的信息
update Student set name ='xuli';
select * from Student;
//<2>按照某个条件修改信息
update Student set name = '双月' where ID=1;
update Student set name = '玲玲',age=18,birthDay='1996-10-10' where ID=2;
//<3>按照多个条件查询
select * from Student where ID=1 and age=18;
select * from Student where ID = 1 or age = 18;
//删除
//<1>按照条件删除
delete from Student where ID = 1;
select * from Student;
//<2>删除表格中的所有数据
delete from Student;

FMDB使用

//同名数据库只能创建一个 如果第二次创建同名数据库 会创建失败 但是会将原来的数据库打开
FMDatabase * database;
//数据库的创建/表格的创建/增删改 操作都用的是同一个方法executeUpdate
//只是SQL语句的内容不同
//数据的查询操作使用的方法是executeQuery:
//[注意]使用sql语句不能向数据库表格中存放自定义的对象指针 只能存放系统提送的数据类型
使用单例方法创建当前类的对象 确保数据库和表格值创建一次
1.单例创建数据库
//创建数据库
NSString * path = [NSHomeDirectory() stringByAppendingString:@"/Documents/PersonDB.db"];
//初始化对象
FMDatabase * fmdb = [[FMDatabase alloc]initWithPath:path];
//打开数据库
BOOL isSuccess = [fmdb open];
if (isSuccess) {
NSString * sql = @"create table if not exists UserInfo(ID integer primary key,name varchar(256),age integer,image blob)";
BOOL isTable = [fmdb executeUpdate:sql];
if (isTable) {
NSLog(@"success");
}else
{
NSLog(@"%@",fmdb.lastErrorMessage);
}
}else{
NSLog(@"数据库创建/打开失败%@",fmdb.lastErrorMessage);
}
2.增
int personID = person.personID;
NSString * personName = person.personName;
int age = person.personAge;
UIImage * personImage = person.personHeadImage;
NSString * sql = @"insert into UserInfo(ID,name,age,image) values(?,?,?,?)";
BOOL isSucess = [fmdb executeUpdate:sql,@(personID),personName,@(age),UIImagePNGRepresentation(personImage)];
if (isSucess) {
NSLog(@"insert success");
}
3.删
NSString * sql = @"delete from Person where name = ?";
BOOL isSuccess = [database executeUpdate:sql,@"wang"];
if (isSuccess) {
NSLog(@"delete success");
}else{
NSLog(@"delete false");
}
4.改
NSString * sql = @"update UserInfo set name = ?,age = ?,image = ? where ID = ?";
BOOL isSuccess = [fmdb executeUpdate:sql,person.personName,@(person.personAge),UIImagePNGRepresentation(person.personHeadImage),@(person.personID)];
if (isSuccess) {
NSLog(@"update success");
}
5.查
NSString * sql = @"select * from UserInfo";
FMResultSet * result = [fmdb executeQuery:sql];
//定义一个数组存放表格中的所有对象
NSMutableArray * allUserInfo = [[NSMutableArray alloc]init];
while ([result next]) {
//遍历表格的一行就是一个对象
PersonInfo * person = [[PersonInfo alloc]init];
person.personID = [result intForColumn:@"ID"];
person.personName = [result stringForColumn:@"name"];
person.personAge = [result intForColumn:@"age"];
person.personHeadImage = [UIImage imageWithData:[result dataForColumn:@"image"]];
[allUserInfo addObject:person];
}
return allUserInfo;

6.CoreData使用

coreData能够存放任意类型的对象指针包括自定义的对象指针

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,602评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,442评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,878评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,306评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,330评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,071评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,382评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,006评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,512评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,965评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,094评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,732评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,283评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,286评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,512评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,536评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,828评论 2 345

推荐阅读更多精彩内容