首页 > 代码库 > 开源类库之二 (FMDataBase)

开源类库之二 (FMDataBase)

FMDataBase是iOS平台中一个非常强大的数据库类库,其将sqlite面向过程的接口以面向对象的方法展现出来,提供了极高的可用性。

其使用很简单,将sqlite 库添加到项目中,然后将FMDataBase类库文件添加到项目中,下面是对笔者对FMDataBase进行的一个二次封装,处理的数据库很简单,只有一张表,两个列,存储的都是一些key-value对,读者可以根据自身需要对此类进行修改。

[cpp] view plaincopy
  1. #import <Foundation/Foundation.h>  
  2. #import "FMDatabase.h"  
[cpp] view plaincopy
  1. @interface DBController : NSObject {  
  2. }  
  3.   
  4. @property (nonatomic, assign) FMDatabase *dataBase;  
  5.   
  6. +(BOOL)databaseExit;  
  7.   
  8. -(BOOL)initDatabase;  
  9.   
  10. -(void)closeDatabase;  
  11.   
  12. -(BOOL)deleteTable;  
  13.   
  14. -(BOOL)InsertTable:(NSString *)key_type value:(NSString *)key_value;  
  15.   
  16. -(BOOL)UpdataTable:(NSString *) valueStr key:(NSString *)keyStr;  
  17.   
  18. -(NSMutableDictionary *)querryTable;  
  19.   
  20. +(BOOL) deleteDataBase;  
  21.   
  22. @end  
  23.   
  24. @synthesize dataBase = _dataBase;  
  25.   
  26. - (id)init{  
  27.       
  28.     if(self = [super init]){  
  29.         _dataBase = [FMDatabase databaseWithPath: [DBController getPath]];  
  30.         if (![_dataBase open]) {  
  31.             NSLog(@"Create/Open dataBase %@ Failed!", [DBController getPath]);  
  32.         }   
  33.     }  
  34.     return self;  
  35. }  
  36.   
  37. //数据库是否存在  
  38. +(BOOL)databaseExit  
  39. {  
  40.     return [[NSFileManager defaultManager] fileExistsAtPath: [self getPath]];  
  41. }  
  42.   
  43.   
  44. //初始化数据库  
  45. -(BOOL)initDatabase{      
  46.     if ([DBController databaseExit]) {  
  47.         return [self createTable];  
  48.     }  
  49.     return NO;  
  50. }  
  51.   
  52.   
  53.   
  54. //创建数据库  
  55. -(BOOL)createTable  
  56. {  
  57.     return [self.dataBase executeUpdate: @"create table if not exists personTable(id integer primary key autoincrement, key text,value text);"];  
  58. }  
  59.   
  60. //删除数据表  
  61. -(BOOL)deleteTable{  
  62.     if ([DBController databaseExit]) {  
  63.         return [self.dataBase executeUpdate: [NSString stringWithFormat:@"drop table %@;",_PERSONINFO]];          
  64.     }  
  65.     return NO;  
  66. }  
  67.   
  68.   
  69.   
  70. //关闭数据库  
  71. - (void) closeDatabase  
  72. {  
  73.     [self.dataBase close];  
  74. }  
  75.   
  76. //插入数据  
  77. -(BOOL)InsertTable:(NSString *)key value:(NSString *)value  
  78. {  
  79.     if ([DBController databaseExit]) {  
  80.         BOOL result = NO;  
  81.         [self.dataBase beginTransaction];  
  82.         result = [self.dataBase executeUpdate:@"INSERT INTO personTable (key,value) VALUES (?,?)", key, value];  
  83.         [self.dataBase commit];  
  84.         return result;  
  85.     }  
  86.     return NO;  
  87. }  
  88.   
  89. //更新数据  
  90. -(BOOL)UpdataTable:(NSString *) valueStr key:(NSString *)keyStr  
  91. {  
  92.     if ([DBController databaseExit]) {  
  93.         BOOL result = NO;  
  94.         [self.dataBase beginTransaction];  
  95.         result = [self.dataBase executeUpdate:@"UPDATE personTable SET value=http://www.mamicode.com/? WHERE key=?", valueStr, keyStr];  
  96.         [self.dataBase commit];  
  97.         return result;  
  98.     }  
  99.     return NO;  
  100. }  
  101.   
  102. //查询整个表  
  103. -(NSMutableDictionary *)querryTable  
  104. {  
  105.     NSMutableDictionary* resultDic = [[NSMutableDictionary alloc] init];  
  106.       
  107.     FMResultSet *rs = [self.dataBase executeQuery:@"select * from personTable"];  
  108.     while ([rs next]) {  
  109.         [resultDic setObject: [rs stringForColumn: @"value"] forKey: [rs stringForColumn: @"key"]];  
  110.     }  
  111.     return [resultDic autorelease];  
  112. }  
  113.   
  114. +(BOOL) deleteDataBase  
  115. {  
  116.     NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);  
  117.       
  118.     NSString *documentsDirectory = [paths objectAtIndex:0];  
  119.       
  120.     NSString *path = [documentsDirectory stringByAppendingPathComponent:_DBNAME];//设置数据库得路径  
  121.       
  122.     NSFileManager *fileManager = [NSFileManager defaultManager];  
  123.       
  124.     BOOL find = [fileManager fileExistsAtPath:path];  
  125.       
  126.     if (find) {  
  127.           
  128.         [fileManager removeItemAtPath: path error: nil];  
  129.           
  130.     }  
  131.     return find;  
  132. }  
  133.   
  134.   
  135. - (void)dealloc {  
  136.     [_dataBase close];  
  137.     _dataBase = nil;  
  138.     [super dealloc];  
  139. }  
  140.   
  141. + (NSString*) getPath {  
  142.     // 打开的数据库  
  143.     NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);  
  144.       
  145.     NSString *documentsDirectory = [paths objectAtIndex:0];  
  146.       
  147.     return [documentsDirectory stringByAppendingPathComponent:_DBNAME];//设置数据库得路径  
  148. }  
  149.   
  150.   
  151. @end  

开源类库之二 (FMDataBase)