IOS开发指南读书笔记11(IOS数据持久层的建立3)

原创 2015年11月18日 11:41:14
IOS开发指南读书笔记11(IOS数据持久层的建立3)
基于SQLite的数据持久的实现

建立SQLite数据管理

//sqlite数据管理

@interface SQLiteNoteDao : NSObject<BaseNoteDao>
{
 
sqlite3* _db;
 
}

#define DBName @"Notes.sqlite3"
 
@end 

为Note添加一个方法

-(id)initWithSqliteStmt:(sqlite3_stmt *)statement

{

    self = [super init];

    if (self) {

        //第二个参数为字段编号从0开始

        char* cID = (char*)sqlite3_column_text(statement, 0);

        self.ID = [[[NSString alloc]initWithUTF8String:cID] integerValue];

        

        char* cContent = (char*)sqlite3_column_text(statement, 1);

        self.content = [[NSString alloc]initWithUTF8String:cContent];

    }

    return self;

}


具体实现

@implementation SQLiteNoteDao


+(id)sharedManager

{

    static dispatch_once_t onceToken;

    __block SQLiteNoteDao* instance = nil;

    dispatch_once(&onceToken, ^{

        instance = [[SQLiteNoteDao alloc]init];

        [instance createObjectCacheFile];

    });

    return instance;

}


-(void)createObjectCacheFile

{

    

    if ([self openDB]) {

        char* err;

        NSString* createTableSQL = @"CREATE TABLE IF NOT EXISTS Note(ID INTEGER PRIMARY KEY,content TEXT)";

        if (sqlite3_exec(_db, [createTableSQL UTF8String], NULLNULL, &err)!= SQLITE_OK) {

            sqlite3_close(_db);

            NSAssert1(NO@"建表失败,%s",err);

        }

        sqlite3_close(_db);

    }

}


-(NSString *)ObjectCacheFilePath

{

    NSString* documentDirectory = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectoryNSUserDomainMaskYESlastObject];

    return [documentDirectory stringByAppendingPathComponent:DBName];

}


-(BOOL)openDB

{

    NSString* dbPath = [self ObjectCacheFilePath];

    if (sqlite3_open([dbPath UTF8String], &_db)!= SQLITE_OK) {

        sqlite3_close(_db);

        NSAssert(NO@"数据库打开失败");

        return NO;

    }

    return YES;

}


-(void)addNote:(Note *)note

{

    if ([self openDB]) {

        NSString* exeSql = @"INSERT INTO Note(ID,content) VALUES(?,?)";

        sqlite3_stmt *statement;

        if (sqlite3_prepare_v2(_db, [exeSql UTF8String], -1, &statement, NULL) == SQLITE_OK) {

            

            sqlite3_bind_text(statement, 1, [[NSString stringWithFormat:@"%d",note.ID]UTF8String], -1nil);

             sqlite3_bind_text(statement, 2, [note.content UTF8String], -1nil);

            

            if (sqlite3_step(statement) != SQLITE_DONE) {

                NSAssert(NO@"数据库插入失败");

            }

        }

        sqlite3_finalize(statement);

        sqlite3_close(_db);

    }

}


-(void)removeNote:(Note *)note

{

    if ([self openDB]) {

        NSString* exeSql = @"DELETE FRON Note where ID=?";

        sqlite3_stmt *statement;

        if (sqlite3_prepare_v2(_db, [exeSql UTF8String], -1, &statement, NULL) == SQLITE_OK) {

            

            sqlite3_bind_text(statement, 1, [[NSString stringWithFormat:@"%d",note.ID]UTF8String], -1nil);

            

            if (sqlite3_step(statement) != SQLITE_DONE) {

                NSAssert(NO@"数据库插入失败");

            }

        }

        sqlite3_finalize(statement);

        sqlite3_close(_db);

    }

}


-(void)modify:(Note *)note

{

    if ([self openDB]) {

        NSString* exeSql = @"UPDATE Note set content=? and ID=?";

        sqlite3_stmt *statement;

        if (sqlite3_prepare_v2(_db, [exeSql UTF8String], -1, &statement, NULL) == SQLITE_OK) {

            

            sqlite3_bind_text(statement, 2, [[NSString stringWithFormat:@"%d",note.ID]UTF8String], -1nil);

            sqlite3_bind_text(statement, 1, [note.content UTF8String], -1nil);

            

            if (sqlite3_step(statement) != SQLITE_DONE) {

                NSAssert(NO@"数据库插入失败");

            }

        }

        sqlite3_finalize(statement);

        sqlite3_close(_db);

    }

}


-(NSMutableArray*)queryAllNote

{

    NSMutableArray* datas = [NSMutableArray array];

    if ([self openDB]) {

        NSString* exeSql = @"SELECT * FROM Note";

        sqlite3_stmt *statement;

        if (sqlite3_prepare_v2(_db, [exeSql UTF8String], -1, &statement, NULL) == SQLITE_OK) {

            

            while (sqlite3_step(statement) == SQLITE_ROW) {

                Note* note = [[Note alloc]initWithSqliteStmt:statement];

                [datas addObject:note];

            }

        }

        sqlite3_finalize(statement);

        sqlite3_close(_db);

    }

    return datas;

}


-(Note*)queryNoteByID:(NSInteger)ID

{

    if ([self openDB]) {

        NSString* exeSql = [NSString stringWithFormat:@"SELECT * FROM Note where ID=%d",ID];

        sqlite3_stmt *statement;

        if (sqlite3_prepare_v2(_db, [exeSql UTF8String], -1, &statement, NULL)) {

            //第二个参数为字段编号从1开始

            sqlite3_bind_text(statement, 1, [[NSString stringWithFormat:@"%d",ID]UTF8String], -1NULL);

            

            if (sqlite3_step(statement) == SQLITE_ROW) {

                Note* note = [[Note alloc]initWithSqliteStmt:statement];

                sqlite3_finalize(statement);

                sqlite3_close(_db);

                return note;

            }

        }

        sqlite3_finalize(statement);

        sqlite3_close(_db);

    }

    return nil;

}



@end 


IOS开发指南读书笔记12(IOS数据持久层的建立4)

IOS开发指南读书笔记12(IOS数据持久层的建立4)  建立CoreData需要首先建立一个模型文件 生成的后缀是xcdatamodeid,但是编译之后在沙盒的momd文件 首先A...
  • hahahakonghee
  • hahahakonghee
  • 2015年11月18日 11:42
  • 630

IOS开发指南读书笔记10(IOS数据持久层的建立2)

IOS开发指南读书笔记10(IOS数据持久层的建立2) 基于对象归档的实现 建立对象归档数据管理类 实现归档数据持久的对象实现NSCoding协议 其属性也必须是基本类型或者实现N...
  • hahahakonghee
  • hahahakonghee
  • 2015年11月18日 11:40
  • 291

OS开发指南读书笔记9(IOS数据持久层的建立1)

IOS开发指南读书笔记9(IOS数据持久层的建立1)  建立IOS数据持久层,有以下几个方式 1、文本文件 plist/Xml/Json/NSUserDefault(等同于plist) 2、...
  • hahahakonghee
  • hahahakonghee
  • 2015年11月18日 11:39
  • 393

iOS 分层架构设计

> 衡量一个软件架构设计好坏的原则是:可复用性和可扩展性 > 有关信息处理的应用应该采用分层架构设计,而游戏等应用不会采用这种分层架构设计(一般都会采用某个引擎) iOS分层架构设...
  • sinat_26547981
  • sinat_26547981
  • 2016年03月04日 11:18
  • 525

IOS开发指南读书笔记3(视图的生命周期)

IOS开发指南读书笔记3(视图的生命周期) 1、视图的生命周期 ViewDidLoad方法只会调用一次,而viewWillAppear:、viewDidAppear:、viewWill...
  • hahahakonghee
  • hahahakonghee
  • 2015年11月18日 11:34
  • 362

两种语言,一个平台——《iOS开发指南:从Hello World到App Store上架(第4版)》

一个人做厨师几年也做不出好吃的菜,再怎么培训也做不好iOS;一个人只要勤学苦练,学好iOS只要看一本《iOS开发指南:从Hello World到App Store上架(第4版)》就够了。...
  • dongfeng9ge
  • dongfeng9ge
  • 2016年09月05日 08:20
  • 2925

《iOS开发指南》正式出版-源码-样章-目录,欢迎大家提出宝贵意见

我的最新作品:《iOS开发指南-从0基础到AppStore上线》一书电子版图灵社区上线了iOS架构设计、iOS性能优化、iOS测试驱动、iOS调试、iOS团队协作版本控制。。。。。。...
  • tonny_guan
  • tonny_guan
  • 2013年06月09日 15:42
  • 4686

1-读书笔记----iOS开发指南:从零基础到App Store上架--iOS入门

iOS的系统架构分为4层——Cocoa Touch层、Media层、Core Services层和Core OS层 AppDelegate类是应用程序委托对象,这个类中继承的一系列方法在应用生...
  • blacet
  • blacet
  • 2015年11月08日 21:46
  • 985

Delphi for iOS开发指南(2):在Windows PC上配置你的开发环境

在这篇教程开始之前,你应该阅读并按教程里的步骤执行: “Delphi for iOS开发指南(1):在Mac上配置你的开发环境”   为iOS目标平台开发的FireMonkey应用程序最初可以在...
  • wei_wu49036233
  • wei_wu49036233
  • 2013年09月03日 09:09
  • 3039

十分钟搭建iOS App主流框架

搭建主流框架界面 0.达成效果 我们玩iPhone应用的时候,有没发现大部分的应用都是上图差不多的结构,下面的TabBar控制器可以切换子控制器,上面又有Navigation导航...
  • m372897500
  • m372897500
  • 2016年05月27日 14:58
  • 596
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:IOS开发指南读书笔记11(IOS数据持久层的建立3)
举报原因:
原因补充:

(最多只允许输入30个字)