IOS 学习笔记 2015-04-09 0C-SQLite 数据存储
1 项目导入 libsqlite3.0.dylib 框架
2 在使用数据sqlite的头文件(.h)上导入 #Impourt <sqlite3.h>
3 推荐自己本地电脑下个sqlite Manager 管理软件类似的
下面上代码
//
// ViewController.m
// SQLiteDemo
//
// Created by wangtouwang on 15/4/9.
// Copyright (c) 2015年 wangtouwang. All rights reserved.
// #import "ViewController.h"
#import "WPUser.h" #define DBNAME @ "mysqlite.sqlite" @interface ViewController ()
{
sqlite3 *db;
}
@end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad]; [self createSqlDBOrOpenDB]; [self createTable]; // for (int index=0; index<30; index++) {
// [self insertIntoData];
// } [self updateData:[self searchAllData]]; } #pragma mark 更新数据
-(void)updateData:(NSMutableArray *)array{
NSString *sql = @"update user set name=?,age=? where id=?";
sqlite3_stmt *stmt;
for (int index=; index<array.count; index++) {
WPUser *user = (WPUser *)array[index];
user.name=@"张建华";
user.age=;
if (sqlite3_prepare_v2(db, [sql UTF8String], -, &stmt, NULL)==SQLITE_OK) {
sqlite3_bind_text(stmt, , [user.name UTF8String], -, NULL);
sqlite3_bind_int(stmt, , user.age);
sqlite3_bind_int(stmt, , user.ID);
if (sqlite3_step(stmt)==SQLITE_DONE) {
NSLog(@"更新成功");
}
}
}
} #pragma mark 读取数据
-(NSMutableArray *)searchAllData{
NSMutableArray *array = [NSMutableArray array];
NSString *sql = @"select id,name,age from user";
sqlite3_stmt *stmt;
if (sqlite3_prepare_v2(db, [sql UTF8String], -, &stmt, NULL)==SQLITE_OK) {
while (sqlite3_step(stmt)==SQLITE_ROW) {
NSInteger ID = sqlite3_column_int(stmt, );
char *name = (char*)sqlite3_column_text(stmt, );
NSString *uname = [[NSString alloc] initWithUTF8String:name];
NSInteger age = sqlite3_column_int(stmt, );
NSLog(@"ID=%lu NAME=%s AGE=%lu",ID,name,age);
WPUser *user = [WPUser initUserName:uname Age:age];
user.ID=ID;
[array addObject:user];
}
}
sqlite3_close(db);
return array;
} #pragma mark 新增数据
-(void)insertIntoData{
NSString *sql = @"insert into user(name,age) values(?,?)";
WPUser *user = [WPUser initUserName:@"JACK" Age:];
sqlite3_stmt *stmt;
//插入数据前检测语法是否正确
if ((sqlite3_prepare_v2(db, [sql UTF8String], -, &stmt, NULL))==SQLITE_OK ) {
//绑定参数 参数2:为序号(从1开始),参数3:为字符串值,参数4 为字符串长度。sqlite3_bind_text的第五个参数为一个函数指针
sqlite3_bind_text(stmt, , [user.name UTF8String], -, NULL);
sqlite3_bind_int(stmt, ,user.age);
//真正执行插入 sqlite3_step
if (sqlite3_step(stmt)==SQLITE_DONE) {
NSLog(@"INSERT INTO SUCCESS");
}else{
NSLog(@"INSERT INTO ERROR");
}
}
} #pragma mark 创建表
-(void)createTable{
NSString *sql = @"create table if not exists user (id integer primary key autoincrement,name text,age integer);";
char *errormsg;
//执行创建语句 sqlite3_exex 是函数 参数一:数据库的句柄(db),参数二: 为sql语句,参数三 回调参数,是一个指向函数的指针,如果把callback前面的*改成^则就是一个block代码段,
//参数四 可以写NULL,第五个参数为错误信息
//在这里创建需要先判断表是否已存在
int result = sqlite3_exec(db, [sql UTF8String], NULL, NULL, &errormsg);
if (result==SQLITE_OK) {
NSLog(@"创建成功");
}else{
NSLog(@"创建失败 愿因是:%s",errormsg);
}
} #pragma mark 创建数据库实例或者打开数据实例
-(void)createSqlDBOrOpenDB{
//获取 项目 Doucment文件目录地址
NSString *doc = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
NSLog(@"%@",doc);
//创建 SQLITE 文件或者获取该文件路径
NSString *DB_PATH = [doc stringByAppendingPathComponent:DBNAME];
NSLog(@"%@",DB_PATH);
//打开或者创建DB实例 这里用到C里面的语法和指针
int result = sqlite3_open([DB_PATH UTF8String], &db);//sqlite3_open方法名 参数 const filename DB文件路径,第二个参数就是数据库实例化对象 返回参数 int 类型
if(result!=SQLITE_OK){
sqlite3_close(db);//关闭实例化
NSLog(@"打开数据哭实例化对象失败");
}else{
NSLog(@"CREATE SUCCESS");
}
} @end
//
// WPUser.m
// SQLiteDemo
//
// Created by wangtouwang on 15/4/9.
// Copyright (c) 2015年 wangtouwang. All rights reserved.
// #import "WPUser.h" @implementation WPUser -(instancetype)initUserName:(NSString *)name Age:(NSInteger)age{
if (self= [super init]) {
self.name = name;
self.age = age;
}
return self;
} +(instancetype)initUserName:(NSString *)name Age:(NSInteger)age{
return [[WPUser alloc] initUserName:name Age:age];
} @end
IOS 学习笔记 2015-04-09 0C-SQLite 数据存储的更多相关文章
- IOS学习笔记之获取Plist文件读取数据
@property(nonatomic,strong) NSArray *pic; //创建数组属性 @property(nonatomic,assign) int index; //创建索引属性 @ ...
- iOS学习笔记16-数据库SQLite
一.数据库 在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等.离线缓存一般都是把数据保存到项目的沙盒中.有以下几种方式: 归档:NSKeyedArchiver 偏好设置:NSU ...
- IOS学习笔记25—HTTP操作之ASIHTTPRequest
IOS学习笔记25—HTTP操作之ASIHTTPRequest 分类: iOS2012-08-12 10:04 7734人阅读 评论(3) 收藏 举报 iosios5网络wrapper框架新浪微博 A ...
- iOS学习笔记17-FMDB
上一节我已经介绍了SQLite的简单使用,不了解的可以提前去看一下iOS学习笔记16-数据库SQLite,这节我们来讲下FMDB. 一.FMDB介绍 FMDB是一种第三方的开源库,FMDB就是对SQL ...
- iOS学习笔记17-FMDB你好!
上一节我已经介绍了SQLite的简单使用,不了解的可以提前去看一下iOS学习笔记16-数据库SQLite,这节我们来讲下FMDB. 一.FMDB介绍 FMDB是一种第三方的开源库,FMDB就是对SQL ...
- Java学习笔记(04)
Java学习笔记(04) 如有不对或不足的地方,请给出建议,谢谢! 一.对象 面向对象的核心:找合适的对象做合适的事情 面向对象的编程思想:尽可能的用计算机语言来描述现实生活中的事物 面向对象:侧重于 ...
- iOS学习笔记——AutoLayout的约束
iOS学习笔记——AutoLayout约束 之前在开发iOS app时一直以为苹果的布局是绝对布局,在IB中拖拉控件运行或者直接使用代码去调整控件都会发上一些不尽人意的结果,后来发现iOS在引入了Au ...
- IOS学习笔记之关键词@dynamic
IOS学习笔记之关键词@dynamic @dynamic这个关键词,通常是用不到的. 它与@synthesize的区别在于: 使用@synthesize编译器会确实的产生getter和setter方法 ...
- iOS学习笔记-精华整理
iOS学习笔记总结整理 一.内存管理情况 1- autorelease,当用户的代码在持续运行时,自动释放池是不会被销毁的,这段时间内用户可以安全地使用自动释放的对象.当用户的代码运行告一段 落,开始 ...
- iOS学习笔记10-UIView动画
上次学习了iOS学习笔记09-核心动画CoreAnimation,这次继续学习动画,上次使用的CoreAnimation很多人感觉使用起来很繁琐,有没有更加方便的动画效果实现呢?答案是有的,那就是UI ...
随机推荐
- mongodb的固定集合(优化效率)
mongodb固定集合(Capped Collection)和大文件管理(GridFS) Capped Collection 固定集合(Capped Collection)是性能出色的有着固定 ...
- map的基本操作函数及含义
map的基本操作函数: C++ Maps是一种关联式容器,包含“关键字/值”对 begin() 返回指向map头部的迭代器 clear() ...
- 遇到Class Not registered的COM异常怎么办
博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:遇到Class Not registered的COM异常怎么办.
- 软中断&tasklet&工作队列
软中断 软中断的分配时静态的(即在编译时定义),而tasklet的分配和初始化能够在执行时进行. 软中断(即便是同一种类型的软中断)能够并发地运行在多个CPU上. 因此,软中断是可重入函数并且必须明白 ...
- pair的例子
11.12 编写程序,读入string和int的序列,将每个string和int存入一个pair中,pair保存在一个vector中. #include<iostream> #includ ...
- iOS开发简单高效的数据存储
在iOS开发过程中,不管是做什么应用,都会碰到数据保存的问题,你是用什么方法来持久保存数据的?这是在几乎每一次关于iOS技术的交流或讨论都会被提到的问题,而且大家对这个问题的热情持续高涨.本文主要从概 ...
- Flash学习初总结
话说尝试了一周多的Flash编程,有些理解为什么很多程序员都不喜欢用Flash编程了. 首先,就是没有编程的难度,想要编好Flash,也就是有良好的视觉效果,那么关键点不在你的程序逻辑或者代码条理上, ...
- Python开发笔记之正则表达式的使用
查找正则表达式 import re re_txt = re.compile(r'(\d)*.txt') m = re_txt.search(src) if not m == None: m.group ...
- 7.Composer的安装和使用
1.安装Composer: 局部安装 要真正获取 Composer,我们需要做两件事.首先安装 Composer (同样的,这意味着它将下载到你的项目中): curl -sS https://getc ...
- addEventListener 用法
addEventListener 用于注册事件处理程序,IE 中为 attachEvent,我们为什么讲 addEventListener 而不讲 attachEvent 呢?一来 attachEve ...