fmdb 数据库简单使用

       FMDB 学习笔记

//

//  UserDB.m

//  FMDB

//

//  Created by GuoBIn on 15/7/20.

//  Copyright (c) 2015 自强不息. All rights reserved.

//


#import "UserDB.h"

#import <FMDB.h>


#define dataBasePath [[(NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES)) lastObject]stringByAppendingPathComponent:dataBaseName]

#define dataBaseName @"GuoBIn.sqlite"


static UserDB *instnce;


@implementation UserDB


+ (id)shareInstance

{

    if (instnce == nil) {

        instnce = [[[self class] alloc] init];

    }

    return instnce;

}


// 创建用户表

- (void)createTable

{

    // 文件路径

    NSString *filePath = [NSHomeDirectory() stringByAppendingFormat:@"/Documents/%@",dataBaseName];

    NSLog(@"文件路径 == %@",filePath);


    FMDatabase *db = [FMDatabase databaseWithPath:dataBasePath];

    

    if ([db open]) {

        if (![db tableExists:@"user"]) {

            if ([db executeUpdate:@"CREATE TABLE user (Serial text primary key,dataText text)"]) {

                NSLog(@"创建表成功");

            }else{

                NSLog(@"创建表失败");

            }

        } else {

            NSLog(@"表已经存在");

        }

    } else{

        NSLog(@"打开表失败");

    }

    [db close];     // 打开就要关闭

    

}


// 添加用户

- (void)addData:(NSArray *)dataArray

{

    NSString *serial   = [dataArray objectAtIndex:0];

    NSString *dataText = [dataArray objectAtIndex:1];

    

    FMDatabase *db = [FMDatabase databaseWithPath:dataBasePath];

    if ([db open]) {

    // 插入数据

    BOOL rs = [db executeUpdate:@"insert into user (Serial,DataText) values(?,?)",serial,dataText,nil];

        if (rs) {

            NSLog(@"添加成功");

        } else {

            NSLog(@"添加失败");

        }

    }

    [db close];

}


// 查询用户

- (NSArray *)findDatas

{

    NSMutableArray *users = [NSMutableArray array];

    FMDatabase *db = [FMDatabase databaseWithPath:dataBasePath];

    if ([db open]) {

        // 获取所有数据

        FMResultSet *rs = [db executeQuery:@"SELECT * FROM user"];

        while ([rs next]) {

            NSString *serial = [rs stringForColumn:@"Serial"];

            NSString *dataText = [rs stringForColumn:@"DataText"];

            

            [users addObject:@[serial,dataText]];

        }

        [rs close];

    }

    [db close];

    return users;

}


- (void)deleteRowData:(NSArray *)array

{

    NSString *serial = [array objectAtIndex:0];

    NSString *dataText = [array objectAtIndex:1];

    

    FMDatabase *db = [FMDatabase databaseWithPath:dataBasePath];

    if ([db open]) {

        // 删除某个数据

        BOOL rs = [db executeUpdate:@"DELETE FROM user WHERE Serial = ? and DataText = ?",serial,dataText];

        

        if (rs) {

            NSLog(@"删除成功");

        } else {

            NSLog(@"删除失败");

        }

    }

    [db close];

}


// 清空表中的数据:

- (void)clearTableData

{

    FMDatabase *db = [FMDatabase databaseWithPath:dataBasePath];

    if ([db open]) {

        // 清除全部数据

        [db executeUpdate:@"DELETE FROM user"];

    }

    [db close];

}


// 更新数据

- (void)executeUpdate:(NSArray *)array

{

    NSString *serial = [array objectAtIndex:0];

    NSString *dataText = [array objectAtIndex:1];

    

    FMDatabase *db = [FMDatabase databaseWithPath:dataBasePath];

    if ([db open]) {

        [db executeUpdate:@"UPDATE user SET DataText = ? WHERE Serial = ?",dataText,serial];

    }

    [db close];

    

}


@end


好记性,不如烂笔头

https://github.com/19940524/LCY_FMDB.git  


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值