FMDB使用方法

** 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;
    
    
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值