//

//  GroupDBManager.h

#import

#import "GroupDBmodel.h"

@interface GroupDBManager : NSObject

//此方法返回DBManager的单例

+(GroupDBManager *)shareManager;

// 添加一条数据

- (void)insertDataWithModel:(GroupDBmodel *)model;

- (void)deleteMessageWithChatId:(NSString*)chatId;

// 修改数据库中的某一条数据

//- (void)updateWithModel:(GroupDBmodel *)model uuid:(int)uuid;

/** 更新数据的创建时间

 @pragma createTime     创建信息的时间

 @pragma status         发送状态(0 未发送 1 已发送)

 @pragma uuid           数据库表中信息的uuid

 */

//- (BOOL)updateModelWithCreateTime:(NSString *)createTime andStatus:(NSString *)status andUuid:(int)uuid;

// 获取全部数据

- (NSArray *)fetchAllgroupBulletin;

// 获取对应 questionID 下的所有数据

- (NSArray *)fetchAllHistoryWithQuestionID:(NSString *)questionID;

// 获取对应 questionID 下的最大时间

- (NSString *)findmaxtime:(NSString *)questionID;

// 获取一个新的uuid(uuid里的最大值)

- (int)findMaxUuid;

// 判断是否存在该条记录

- (BOOL)isExistModel:(NSString*)chatId;

// 删除整个表

- (void)deleteDBFile;


//

//  GroupDBManager.m


#import "GroupDBManager.h"

#import "FMDatabase.h"//第三方开源库,里面封装了对苹果原生sqlite3轻量级数据库的操作

@implementation GroupDBManager

{

FMDatabase *_dataBase;

}

//被 static 关键字修饰的变量,只执行一次初始化操作,并且变量会一直持有第一次初始化得到的对象

staticGroupDBManager *manager = nil;

+(GroupDBManager *)shareManager{

if (manager == nil) {

manager = [[GroupDBManageralloc] init];

    }

returnmanager;

}

//重写init方法

- (id)init{

self = [superinit];

if (self) {

//为数据库文件指定创建的路径

NSString *dbPath = [NSHomeDirectory() stringByAppendingFormat:@"/Documents/groupBulletin.db"];

//初始化FMDataBase对象,并传递数据库的路径

_dataBase = [[FMDatabasealloc] initWithPath:dbPath];

//open 两层含义:如果指定路径没有user.db的数据库文件,会创建此文件并打开;如果指定路径有数据库文件则直接打开

//如果创建并打开成功 return yes

        [selfcreateDBFile];

    }

returnself;

}

// 创建数据库文件

- (void)createDBFile{

if ([_dataBaseopen]) {

//创建一个表, blob 代表二进制的对象

NSString *createSql = @"CREATE TABLE IF NOT EXISTS groupBulletin (id integer primary key autoincrement , chatter varchar(256) , chatId varchar(256) , groupText varchar(256) , headPhoto varchar(256) , senderName varchar(256) , senderTime varchar(256))";

//executeUpdate 执行sql语句的方法,创建表、增、删、改的sql语句全用此方法执行

//执行sql语句成功返回YES

BOOL isSuccessed =[_dataBaseexecuteUpdate:createSql];

if (!isSuccessed) {

//创建表失败,lastErrorMessage 获取到出错的信息

NSLog(@"error:%@",_dataBase.lastErrorMessage);

        }

    }

}

//添加一条数据

- (void)insertDataWithModel:(GroupDBmodel *)model{

//        UIImage *headImage = model.img;

//    //转化成NSData (将png格式的图片转化成NSData,几乎是无损耗转化)

//        NSData *data = UIImagePNGRepresentation(headImage);

//    //sql语句中,用?作为占位符,不管是什么样类型的数据

//    [self createDBFile];

if ([selfisExistModel:model.chatId]) {

NSLog(@"存在该条");

return;

    }

else {

NSString * insertSQL = @"INSERT INTO groupBulletin(chatter,chatId,groupText,headPhoto,senderName , senderTime) VALUES(?,?,?,?,?,?)";

BOOL isSuccessed = [_dataBaseexecuteUpdate:insertSQL,model.chatter,model.chatId,model.groupText,model.headPhoto,model.senderName,model.senderTime];

if (!isSuccessed) {

NSLog(@"insertError:%@",_dataBase.lastErrorMessage);

        }

    }

}

//删除某条数据

- (void)deleteMessageWithChatId:(NSString*)chatId

{

NSString *deleteSQL=@"delete from groupBulletin where chatId = ?";

BOOL isSuccessed = [_dataBaseexecuteUpdate:deleteSQL,chatId];

if (!isSuccessed) {

NSLog(@"insertError:%@",_dataBase.lastErrorMessage);

    }

}

- (BOOL)isExistModel:(NSString*)chatId{

FMResultSet * set = [_dataBaseexecuteQuery:@"SELECT * FROM groupBulletin WHERE chatId = ?",[NSNumbernumberWithInt:[chatId intValue]]];

if ([set next]) {

returnYES;

    }

else {

returnNO;

    }

}

//修改数据库中的某一条数据

//- (void)updateWithModel:(GroupDBmodel *)model id:(int)id{

//

//    NSString *updateSql = @"update groupBulletin set chatId = ?  where id =?";

//    BOOL isSuccessed = [_dataBase executeUpdate:updateSql,model.chatId,[NSNumber numberWithInt:id]];

//    if (!isSuccessed) {

//        NSLog(@"update error:%@",_dataBase.lastErrorMessage);

//    }

//}

/** 更新数据的创建时间

 */

- (BOOL)updateModelWithCreateTime:(NSString *)createTime andStatus:(NSString *)status andUuid:(int)uuid{

NSString * updateSQL = @"UPDATE groupBulletin SET createTime = ?,status = ? WHERE uuid = ?";

BOOL isSucc = [_dataBaseexecuteUpdate:updateSQL,createTime,status,[NSNumbernumberWithInt:uuid]];

if (!isSucc) {

NSLog(@"update error:%@",_dataBase.lastErrorMessage);

returnNO;

    }

returnYES;

}

//获取全部数据

- (NSArray *)fetchAllgroupBulletin{

NSString *selectSql = @"select * from groupBulletin";

//executeQuery 用于执行查询的sql语句

//FMResultSet 用于存放查询结果的类

FMResultSet *set =[_dataBaseexecuteQuery:selectSql];

//next方法,从第一条数据开始取,一直取到最后一条,取到当前数据返回YES,取不到则返回NO

NSMutableArray *array = [NSMutableArrayarray];

while ([set next]) {

GroupDBmodel *model = [[GroupDBmodelalloc] init];

//stringForColumn 根据字段的名称,取到字段的值

        model.chatId = [set  stringForColumn:@"chatId"];

          }

return array;

}

// 获取对应 questionID 下的所有数据

- (NSArray *)fetchAllHistoryWithQuestionID:(NSString *)questionID{

NSString *selectSql = @"select * from groupBulletin WHERE chatter = ?";

//    //executeQuery 用于执行查询的sql语句

//    //FMResultSet 用于存放查询结果的类

FMResultSet *set =[_dataBaseexecuteQuery:selectSql,questionID];

//    //next方法,从第一条数据开始取,一直取到最后一条,取到当前数据返回YES,取不到则返回NO

NSMutableArray *array = [NSMutableArrayarray];

while ([set next]) {

GroupDBmodel *model = [[GroupDBmodelalloc] init];

//stringForColumn 根据字段的名称,取到字段的值

        model.chatId = [set stringForColumn:@"chatId"];

        model.chatter = [set stringForColumn:@"chatter"];

        model.groupText = [set stringForColumn:@"groupText"];

        model.headPhoto = [set stringForColumn:@"headPhoto"];

        model.senderName = [set stringForColumn:@"senderName"];

        model.senderTime = [set stringForColumn:@"senderTime"];

NSLog(@"%@----%@----%@----%@----%@----%@",model.chatId,model.chatter,model.groupText,model.headPhoto,model.senderName,model.senderTime);

        [array addObject:model];

    }

return array;

}

-(NSString *)findmaxtime:(NSString * )questionID{

//    NSString *selectSql = @"SELECT MAX(createTime) FROM gro upBulletin where questionUuid = ?";

NSString * selectSQL = @"SELECT * FROM groupBulletin WHERE questionUuid = ?";

FMResultSet *set =[_dataBaseexecuteQuery:selectSQL,questionID];

NSMutableArray * mArray = [[NSMutableArrayalloc] init];

while ([set next]) {

NSString * lastTime = [set stringForColumnIndex:6];

if (lastTime) {

            [mArray addObject:lastTime];

        }

    }

if (mArray.count > 0) {

NSString * str = mArray[0];

for (int i = 1 ; i < mArray.count; i++) {

if ([mArray[i] compare:str options:0] > 0) {

                str = mArray[i];

            }

        }

return str;

    }

else {

return@"0";

    }

}

//-(NSString *)findmaxtime:(NSString * )questionID{

//

//    NSString * selectSQL = @"SELECT * FROM groupBulletin WHERE questionUuid = ?";

//

//    FMResultSet *set =[_dataBase executeQuery:selectSQL,questionID];

//    NSMutableArray * mArray = [[NSMutableArray alloc] init];

//    while ([set next]) {

//        NSString * lastTime = [set stringForColumnIndex:6];

//        return lastTime;

//    }

//    return nil;

//}

- (int)findMaxUuid{

NSString * selectSQL = @"SELECT MAX(uuid) FROM groupBulletin";

int maxUuid = 0;

FMResultSet * set = [_dataBaseexecuteQuery:selectSQL];

while ([set next]) {

//        maxUuid = [set intForColumn:@"uuid"];

        maxUuid = [set intForColumnIndex:0];

    }

return maxUuid;

}

// 删除整个表

- (void)deleteDBFile{

NSString *dbPath = [NSHomeDirectory() stringByAppendingFormat:@"/Documents/groupBulletin.db"];

NSFileManager * fm = [NSFileManagerdefaultManager];

if ([fm fileExistsAtPath:dbPath]) {

if ([_dataBaseopen]) {

NSString * selectSQL = @"DELETE FROM groupBulletin";

            [_dataBaseexecuteUpdate:selectSQL];

            [_dataBaseclose];

        }

        [fm removeItemAtPath:dbPath error:nil];

    }

}

@end