数据库

2015-10-28  本文已影响57人  lion_xion

#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

上一篇 下一篇

猜你喜欢

热点阅读