数据库

#import

#import

#import"Student.h"

@interfacedataBaseTool :NSObject

{

//用来保存数据库对象的地址

sqlite3*dbPoint;

}

//为了保证当前数据库在工程里是唯一的,我们用单例的方式创建一个数据库工具对象

+ (dataBaseTool*)shareBaseDataTool;

//打开数据库

- (void)openDB;

//给数据库创建张表格,table

- (void)createTable;

- (void)insertStu:(Student*)stu;

//更新表里的学生数据

- (void)updateStu:(Student*)stu;

- (void)deleteStu;

- (NSMutableArray*)selectAllStu;

@end

********************************************************************************

#import"dataBaseTool.h"

@implementationdataBaseTool

+ (dataBaseTool*)shareBaseDataTool{

staticdataBaseTool*tool;

staticdispatch_once_toneToken;

dispatch_once(&oneToken, ^{

tool = [[dataBaseToolalloc]init];

});

returntool;

}

- (void)openDB{

//数据库文件也保存在沙盒documents文件里,所以先找沙盒路径

NSArray*sandBox =NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES);

NSString*sandBoxPath = sandBox[0];

//拼接文件路径,如果系统根据这个路径查找的时候有对应文件则直接打开数据库,如果没有则会创建一个相应的数据库

NSString*documentPath = [sandBoxPathstringByAppendingPathComponent:@"Student.sqlite"];

intresult=sqlite3_open([documentPathUTF8String], &dbPoint);

if(result ==SQLITE_OK) {

NSLog(@"打开数据库成功");

NSLog(@"%@",documentPath);

}else{

NSLog(@"打开数据库失败");

}

}

- (void)createTable{

// primary key是逐渐的意思,主键在当前表里数据是唯一的,不能重复,可以唯一标示一条数据,一般是整数

// autoincrement自增,为了让主键不重复,会让主键采用自增的方式

// if note exists如果没有表才会创建,防止重复创建覆盖之前的数据

//数据库问题90%是sql语句出现了问题,所以先保证语句没问题,在放到工程里使用

NSString*sqlStr =@"create table if not exists stu(number integer primary key autoincrement, name text, sex text, age integer, hobby text)";

//执行这条sql语句

intresult =sqlite3_exec(dbPoint, [sqlStrUTF8String],nil,nil,nil);

if(result ==SQLITE_OK) {

NSLog(@"表创建成功");

}else{

NSLog(@"表创建失败");

}

}

- (void)insertStu:(Student*)stu{

NSString*sqlStr = [NSStringstringWithFormat:@"insert into stu (name,age,sex,hobby) values ('%@', '%ld', '%@', '%@')",stu.name, stu.age, stu.sex, stu.hobby];

//执行sql语句

intresult =sqlite3_exec(dbPoint, [sqlStrUTF8String],nil,nil,nil);

if(result ==SQLITE_OK) {

NSLog(@"添加学生成功");

}else{

NSLog(@"添加学生失败");

}

}

- (void)updateStu:(Student*)stu{

NSString*sqlStr = [NSStringstringWithFormat:@"update stu set name = '%@', sex = '%@', hobby = '%@', age = %ld where sex = '动物'",stu.name, stu.hobby, stu.sex, stu.age];

//执行sql语句

intresult =sqlite3_exec(dbPoint, [sqlStrUTF8String],nil,nil,nil);

if(result ==SQLITE_OK) {

NSLog(@"更新成功");

}else{

NSLog(@"更新失败");

NSLog(@"%d", result);

}

}

- (void)deleteStu{

NSString*sqlStr = [NSStringstringWithFormat:@"delete from stu where name = '张阳阳'"];

intresult =sqlite3_exec(dbPoint, [sqlStrUTF8String],nil,nil,nil);

if(result ==SQLITE_OK) {

NSLog(@"删除成功");

}else{

NSLog(@"删除失败");

NSLog(@"%d", result);

}

}

- (NSMutableArray*)selectAllStu{

//查询逻辑

// 1.先从本地的数据库中读取某张表里的所有数据

// 2.然后逐条进行读取,对model进行赋值

// 3.把已经赋值好的model放到数组中,并且返回

NSString*sqlStr =@"select * from stu";

//在语句里*是通配符的意思,通过一个*相当于代替了表里的所有的字段名

//接下来需要定义一个跟随指针,它用来遍历数据库表中的每行数据

sqlite3_stmt*stmt =nil;

//第三个参数:查询语句字数显示, -1是没有限制

intresult =sqlite3_prepare_v2(dbPoint, [sqlStrUTF8String], -1, &stmt,nil);

//这个方法相当于把数据库和跟随指针相关联,一同完成查询功能

//初始化一个用来装学生的数组

NSMutableArray*stuArr = [NSMutableArrayarray];

if(result ==SQLITE_OK) {

NSLog(@"查询成功");

//开始遍历数据库的每一行数据

while(sqlite3_step(stmt) ==SQLITE_ROW){

//让跟随指针进行遍历查询,如果没有行,才会停止循环

//满足条件,则逐列的读取内容

//第二个参数表示当前这列数据在表的第几列

constunsignedchar*name =sqlite3_column_text(stmt,1);

constunsignedchar*sex =sqlite3_column_text(stmt,2);

intage =sqlite3_column_int(stmt,3);

constunsignedchar*hobby =sqlite3_column_text(stmt,4);

//把列里的数据再进行类型的转换

NSIntegerstuAge = age;

NSString*stuName = [NSStringstringWithUTF8String:(constchar*)name];

NSString*stuSex = [NSStringstringWithUTF8String:(constchar*)sex];

NSString*stuHobby = [NSStringstringWithUTF8String:(constchar*)hobby];

//给对象赋值,然后把对象放到数组里

Student*stu = [[Studentalloc]init];

stu.name= stuName;

stu.hobby= stuHobby;

stu.age= stuAge;

stu.sex= stuSex;

[stuArraddObject:stu];

[sturelease];

}

}else{

NSLog(@"查询失败");

NSLog(@"%d", result);

}

returnstuArr;

}

@end

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

推荐阅读更多精彩内容