** FMDB建立單例的使用方法*
//單利方法
+(instancetype)initData;
//初始化資料庫
-(void)initSql;
//初始化表格
-(void)initTable;
//添加資料
-(void)addData:(ClassMessage *)data;
//修改資料
-(void)upData:(ClassMessage *)data;
//删除資料
-(void)deleteData:(NSInteger )theid;
//查詢資料
-(NSMutableArray *)array;
//關閉資料庫
-(void)closeSql;
.m檔案
//建立靜态變量
static SqlData *sqlData1;
static FMDatabase *db;
//單利方法
+ (instancetype)initData{
if (!sqlData1) {
sqlData1 = [[SqlData alloc] init];
}
return sqlData1;
}
//初始化資料庫
- (void)initSql{
//擷取DOcuments目錄
NSString *str = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)firstObject];
//拼接路徑
NSString *fileName = [str stringByAppendingString:@"/strname.db"];
//建立資料庫
db = [[FMDatabase alloc] initWithPath:fileName];
if ([db open]) {
NSLog(@"資料庫打開成功");
//調用初始化表格方法
[self initTable];
}else{
NSLog(@"資料庫打開失敗");
}
}
//初始化表格
-(void)initTable{
//初始化資料庫表格的格式:create table if not exists 表名(主鍵id integer primary key,所有的資料類型);
[db executeUpdate:@"create table if not exists ClassMessage(classid integer primary key,name text,age text,sex text)"];
//關閉資料庫
[db close];
}
//添加資料
- (void)addData:(ClassMessage *)data{
if ([db open]) {
//添加資料的sql語句:insert into 表名 values(null,?,?);
[db executeUpdate:[NSString stringWithFormat:@"insert into ClassMessage values(null,'%@','%@','%@')",data.name,data.age,data.sex]];
}else{
NSLog(@"添加資料失敗");
}
//關閉資料庫
[db close];
}
//删除資料
- (void)deleteData:(NSInteger)theid{
//sql 語句: delete from 表名 where 表名的主鍵id = ?
if ([db open]) {
[db executeUpdate:[NSString stringWithFormat:@"delete from ClassMessage where classid = '%ld'",theid]];
}else{
NSLog(@"删除資料失敗");
}
//關閉資料庫
[db close];
}
//修改資料
- (void)upData:(ClassMessage *)data{
//sql 語句的格式:update 表名 set 所有資料 where 主鍵id = ?
if ([db open]) {
[db executeUpdate:[NSString stringWithFormat:@"update ClassMessage set name = '%@' ,age = '%@',sex = '%@' where classid = '%ld'",data.name,data.age,data.sex,data.classid]];
}else{
NSLog(@"修改資料失敗");
}
//關閉資料庫
[db close];
}
//查詢資料
- (NSMutableArray *)array{
//建立資料
NSMutableArray *arr = [NSMutableArray array];
//集合
FMResultSet *set = [FMResultSet new];
if ([db open]) {
//sql 語句格式:select *from 表名
set = [db executeQuery:@"select *from ClassMessage"];
// 判斷有沒有查詢到 一行一行去查詢
while ([set next]) {
ClassMessage *msg = [[ClassMessage alloc] init];
msg.classid = [set intForColumn:@"classid"];
msg.name = [set stringForColumn:@"name"];
msg.age = [set stringForColumn:@"age"];
msg.sex = [set stringForColumn:@"sex"];
//将msg對象添加到資料
[arr addObject:msg];
}
}else{
NSLog(@"查詢失敗");
}
[db close];
return arr;
}