123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- //
- // FFDBSafeOperation.m
- // FFDB
- //
- // Created by Fidetro on 2017/5/15.
- // Copyright © 2017年 Fidetro. All rights reserved.
- //
- // https://github.com/Fidetro/FFDB
- #import "FFDBSafeOperation.h"
- #import "FFDBLog.h"
- #import "FFDataBaseModel+Sqlite.h"
- #import "FFDataBaseModel+Custom.h"
- #import "NSObject+FIDProperty.h"
- #import "NSString+FFDBSQLStatement.h"
- @implementation FFDBSafeOperation
- + (NSArray <__kindof FFDataBaseModel *>*)selectObjectWithFFDBClass:(Class)dbClass
- {
- return [FFDBSafeOperation selectObjectWithFFDBClass:dbClass format:nil];
- }
- + (NSArray <__kindof FFDataBaseModel *>*)selectObjectWithFFDBClass:(Class)dbClass
- format:(NSString *)format
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- NSMutableArray *objectList = [NSMutableArray array];
- NSArray *dataColumns = [dbClass columnsOfSelf];
- [queue inDatabase:^(FMDatabase *db) {
- FMResultSet *resultSet;
- resultSet = [db executeQuery:[NSString stringWithSelectColumns:nil fromClasses:@[dbClass] SQLStatementWithFormat:format]];
- while ([resultSet next])
- {
-
- id object = [[dbClass alloc]init];
- for (NSString *propertyname in dataColumns)
- {
- NSString *result = [resultSet stringForColumn:propertyname];
- NSString *objStr = [result length] == 0 ? @"" :result;
- [object setPropertyWithName:propertyname object:objStr];
- }
- [object setPropertyWithName:@"primaryID" object:[resultSet stringForColumn:@"primaryID"]];
- [objectList addObject:object];
- }
- }];
- return [objectList copy];
- }
- + (void)insertObjectList:(NSArray <__kindof FFDataBaseModel *>*)objectList
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- [queue inDatabase:^(FMDatabase *db) {
- for (FFDataBaseModel *dbModel in objectList)
- {
-
- NSString *sql = [NSString stringWithInsertObject:dbModel columns:nil];
- BOOL result = [db executeUpdate:sql];
- if (result == NO)
- {
- FFDBDLog(@"error");
- }
-
- }
- }];
- }
- + (void)updateObjectList:(NSArray<__kindof FFDataBaseModel *> *)objectList
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- [queue inDatabase:^(FMDatabase *db) {
- for (FFDataBaseModel *dbModel in objectList)
- {
-
- NSString *sql = [NSString stringWithUpdateObject:dbModel columns:nil];
- BOOL result = [db executeUpdate:sql];
- if (result == NO)
- {
- FFDBDLog(@"error");
- }
-
- }
- }];
- }
- + (BOOL)updateObjectWithFFDBClass:(Class)dbClass format:(NSString *)format
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- __block BOOL result = NO;
- [queue inDatabase:^(FMDatabase *db) {
-
- result = [db executeUpdate:[NSString stringWithUpdateFromClass:dbClass SQLStatementWithFormat:format]];
- }];
- return result;
- }
- + (void)deleteObjectList:(NSArray<__kindof FFDataBaseModel *> *)objectList
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- [queue inDatabase:^(FMDatabase *db) {
- for (FFDataBaseModel *dbModel in objectList)
- {
- NSString *sql = [NSString stringWithDeleteFromClass:[dbModel class] SQLStatementWithFormat:[dbModel deleteObjectSqlstatement]];
- BOOL result = [db executeUpdate:sql];
- if (result == NO)
- {
- FFDBDLog(@"error");
- }
-
- }
- }];
- }
- + (BOOL)deleteObjectWithFFDBClass:(Class)dbClass
- format:(NSString *)format
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- __block BOOL result = NO;
- [queue inDatabase:^(FMDatabase *db) {
-
- result = [db executeUpdate:[NSString stringWithDeleteFromClass:dbClass SQLStatementWithFormat:format]];
- }];
- return result;
- }
- + (NSArray <__kindof FFDataBaseModel *>*)selectDBToClass:(Class)toClass
- SQLStatementWithFormat:(NSString *)format
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- NSMutableArray *objectList = [NSMutableArray array];
- NSArray *dataColumns = [toClass columnsOfSelf];
- [queue inDatabase:^(FMDatabase *db) {
- FMResultSet *resultSet;
- resultSet = [db executeQuery:format];
- while ([resultSet next])
- {
- id object = [[toClass alloc]init];
- for (NSString *propertyname in dataColumns)
- {
- NSString *result = [resultSet stringForColumn:propertyname];
- NSString *objStr = [result length] == 0 ? @"" :result;
- [object setPropertyWithName:propertyname object:objStr];
- }
- [objectList addObject:object];
- }
- }];
- return [objectList copy];
- }
- + (BOOL)updateDBWithSQLStatementWithFormat:(NSString *)format
- {
- FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:[FFDBManager databasePath]];
- __block BOOL result = NO;
- [queue inDatabase:^(FMDatabase *db) {
-
- result = [db executeUpdate:format];
- }];
- return result;
- }
- @end
|