#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