FMDB使用

FMDBManager.h

#import <Foundation/Foundation.h>
#import "FMDatabase.h"

@interface FMDBManager : NSObject
{
    NSString *dataBasePath;
    FMDatabase * fmdbDataBase;//数据库对象
    BOOL isFMDBopen;
}

+ (FMDBManager *)sharedFMDB;

// 创建表
-(void)createTable;

// 插入记录
-(void)insertTable;

// 获取所有记录
-(NSMutableArray *)getList;

//删除某人所有信息
-(BOOL)deleteUser;


@end

FMDBManager.m

#import "FMDBManager.h"
#import "userModel.h"

#define FMDB_NAME @"test.sqlite3"

static FMDBManager *_sharedFMDB = nil;

@implementation FMDBManager

//共享实例
+(FMDBManager *)sharedFMDB
{
    
    if (_sharedFMDB == nil) {
        _sharedFMDB = [[FMDBManager alloc]init];
    }
    return _sharedFMDB;
}

-(id)init
{
    self = [super init];
    if (self) {
        // Custom initialization
        [self openDataBase];
    }
    return self;
}

-(void)openDataBase
{
    // NSDocumentDirectory (Documents目录下面) NSLibraryDirectory(Library目录下面)
    NSArray *libPaths = NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES);
    dataBasePath=[[libPaths objectAtIndex:0] stringByAppendingPathComponent:FMDB_NAME];
    
    // 创建数据库
    fmdbDataBase = [FMDatabase databaseWithPath:dataBasePath];
    if ([fmdbDataBase open]) {
        isFMDBopen = YES;
    } else {
        isFMDBopen = NO;
        NSLog(@"error when open db");
    }
    
}

// 判断是否存在表
- (BOOL) isTableOK:(NSString *)tableName
{
    FMResultSet *rs = [fmdbDataBase executeQuery:@"select count(*) as 'count' from sqlite_master where type ='table' and name = ?", tableName];
    while ([rs next])
    {
        // just print out what we've got in a number of formats.
        NSInteger count = [rs intForColumn:@"count"];
        
        if (0 == count)
        {
            NSLog(@"表不存在");
            return NO;
        }
        else
        {
            NSLog(@"表已存在");
            return YES;
        }
    }
    
    return NO;
}

// 创建表
-(void)createTable
{
    NSString *strCreatetable = [NSString stringWithFormat:@"CREATE TABLE 'user10086' ('userID' INTEGER PRIMARY KEY AUTOINCREMENT  NOT NULL, 'userName' text, 'passWord' text)"];
    
    if (![self isTableOK:[NSString stringWithFormat:@"%@",@"user10086"]])
    {
        BOOL res = [fmdbDataBase executeUpdate:strCreatetable];
        if (!res)
        {
            NSLog(@"error when creating db table");
        }
        else
        {
            NSLog(@"succ to creating db table");
        }
    }
    
}

// 插入数据
-(void)insertTable
{

    NSString *strInserttable = [NSString stringWithFormat:@"insert into user10086 (userName, passWord) values(?, ?) "];
    BOOL res = [fmdbDataBase executeUpdate:strInserttable,@"testUser",@"123456"];
  
    if (!res) {
        NSLog(@"insert error");
    } else {
        NSLog(@"insert success");
    }
}

// 获取所有记录
-(NSMutableArray *)getList
{
    NSMutableArray *chatList = [[NSMutableArray alloc] init];
    
    NSString *sqlQuery = [NSString stringWithFormat:@"select * from user10086"];
    FMResultSet * rs = [fmdbDataBase executeQuery:sqlQuery];
    while ([rs next]) {
        
        userModel *user = [[userModel alloc] init];
        
        user.userId = [NSString stringWithFormat:@"%d",[rs intForColumn:@"userID"]];
        user.userName = [rs stringForColumn:@"userName"];
        user.passWord = [rs stringForColumn:@"passWord"];
        
        [chatList addObject:user];
    }
    
    return chatList;
}

//删除某一条记录
-(BOOL)deleteUser
{
    NSString *sqlDelete = [NSString stringWithFormat:@"delete from user10086 where userID=%d", 1];
    
    return [fmdbDataBase executeUpdate:sqlDelete];
}


@end

// 使用
  [[FMDBManager sharedFMDB]createTable];
  [[FMDBManager sharedFMDB]insertTable];

 

posted @ 2014-02-24 17:02  菜鸟程序猿  阅读(814)  评论(0编辑  收藏  举报