FMDB的简单使用

//创建数据库,并连接

-(void)createdata

{

   

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

    NSString *file=[doucumentDirectory objectAtIndex:0];

    NSString *dafile=[file stringByAppendingPathComponent:@"db.sqlite"];

    

    if ([[NSFileManager defaultManager]fileExistsAtPath:dafile])

    {

        NSLog(@"数据库已存在");

    }


    db=[FMDatabase databaseWithPath:dafile];

        

    if (!db)

    {

        NSLog(@"数据库创建不成功");

    }

   else

   { if([db open])

    {

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

        FMResultSet * set = [db executeQuery:[NSString stringWithFormat:@"select count(*) from sqlite_master where type ='table' and name = '%@'",kUserTableName]];

        [set next];

        NSInteger count = [set intForColumnIndex:0];

        

        BOOL existTable = count;

        

        if (existTable)

        {

            NSLog(@"数据表已存在,请重新添加表");

            return;}

        else

        {

            NSString *createtable=@"CREATE TABLE user (uid INTEGER PRIMARY KEY AUTOINCREMENT  NOT NULL, name text, interest text)";

            [db executeUpdate:createtable];}

    }


    }

}

//插入数据

-(void)insertdata:(NSArray *)arguments

{

    if ([db open])

    {

        [db executeUpdate:@"INSERT INTO user(name, interest) VALUES(?,?) "withArgumentsInArray:arguments];

            }


}

//查询所有数据

-(NSMutableArray *)selectall

{

   

    NSMutableArray *array=[[NSMutableArray alloc]initWithCapacity:100];

    

    if ([db open])

    {

        NSString *sql=@"select * from user where name=? or interest=?";

        FMResultSet *qureyresult=[db executeQuery:sql,@"333",@"111"];

        

        while ([qureyresult next])

        {

            NSInteger uid=[qureyresult intForColumn:@"uid"];

            NSString *name=[qureyresult stringForColumn:@"name"];

            NSString *inserest=[qureyresult stringForColumn:@"interest"];

            

            NSMutableDictionary *dic=[[NSMutableDictionary alloc]init];

            

            [dic setValue:[NSString stringWithFormat:@"%d",uid]forKey:@"keyuid"];

            [dic setValue:name forKey:@"keyname"];

            [dic setValue:inserest forKey:@"keyinserest"];

            [array addObject:dic];

            

        }

        

    }

    return array;

}

//修改数据

-(void)mergerwithname:(NSString *)name withinterest:(NSString *)interest  anduid:(NSNumber*)uid

{

    if ([db open])

    {

        [db executeUpdate:@"UPDATE user SET name=?,interest=? WHERE uid=? ",name,interest,uid];

    }

}

//删除数据

-(void)deletedata

{

    if ([db open])

    {

        [db executeUpdate:@"delete  from user where name=?",[NSStringstringWithFormat:@"%@",@"eee"]];

    }

}


数据库基本就是更新和查询

除了select,db executeQuery:;其他都是更新db executeUpdate:传参数时可用db executeUpdate:withArgumentsInArray:


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值