123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 |
- //
- // FFDBManager.m
- // FFDB
- //
- // Created by Fidetro on 2017/5/11.
- // Copyright © 2017年 Fidetro. All rights reserved.
- //
- // https://github.com/Fidetro/FFDB
- #import "FFDBManager.h"
- #import "FFDataBaseModel+Sqlite.h"
- #import "NSObject+FIDProperty.h"
- #import "NSString+FFDBSQLStatement.h"
- #import "FFDataBaseModel+Custom.h"
- #import "FMDatabase+FFExtern.h"
- @implementation FFDBManager
- + (NSArray *)selectColumns:(NSArray <NSString *>*)columns
- fromClass:(Class)dbClass
- SQLStatementWithFormat:(NSString *)format
- {
- FMDatabase *database = [self database];
- NSArray *dataColumns = [NSArray array];
- NSMutableArray *dataArray = [NSMutableArray array];
- if (columns.count == 0)
- {
- dataColumns = [dbClass columnsOfSelf];
- }
- else
- {
- dataColumns = columns;
- }
- if ([database open])
- {
- FMResultSet *resultSet;
- resultSet = [database executeQuery:[NSString stringWithSelectColumns:columns 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"]];
- [dataArray addObject:object];
- }
-
- }
-
- [database close];
- return dataArray;
- }
- + (long long int)selectCountfromClasses:(NSArray <Class>*)dbClasses
- SQLStatementWithFormat:(NSString *)format
- {
- FMDatabase *database = [self database];
- long long int totalCount = 0;
- if ([database open])
- {
- FMResultSet *resultSet;
- resultSet = [database executeQuery:[NSString stringWithSelectCountfromClasses:dbClasses SQLStatementWithFormat:format]];
-
- while ([resultSet next])
- {
- totalCount = [resultSet longLongIntForColumnIndex:0];
- }
-
- }
-
- [database close];
- return totalCount;
- }
- + (NSArray <__kindof FFDataBaseModel *>*)selectColumns:(NSArray <NSString *>*)columns
- fromClasses:(NSArray<Class> *)dbClasses
- toClass:(Class)toClass
- SQLStatementWithFormat:(NSString *)format
- {
- NSString *SQLStatement = [NSString stringWithSelectColumns:columns fromClasses:dbClasses SQLStatementWithFormat:format];
- NSArray *dataArray = [self selectDBToClass:toClass SQLStatementWithFormat:SQLStatement];
- return dataArray;
- }
- + (BOOL)deleteFromClass:(Class)dbClass
- SQLStatementWithFormat:(NSString *)format
- {
- FMDatabase *database = [self database];
- return [database executeUpdateWithSqlstatement:[NSString stringWithDeleteFromClass:dbClass SQLStatementWithFormat:format]];
- }
- + (BOOL)insertObject:(__kindof FFDataBaseModel *)model
- columns:(NSArray <NSString *>*)columns
- {
- FMDatabase *database = [self database];
- return [database executeUpdateWithSqlstatement:[NSString stringWithInsertObject:model columns:columns]];
- }
- + (BOOL)updateFromClass:(Class)dbClass
- SQLStatementWithFormat:(NSString *)format
- {
- FMDatabase *database = [self database];
- return [database executeUpdateWithSqlstatement:[NSString stringWithUpdateFromClass:dbClass SQLStatementWithFormat:format]];
- }
- + (BOOL)updateObject:(__kindof FFDataBaseModel *)model
- columns:(NSArray <NSString *>*)columns
- {
- FMDatabase *database = [self database];
- return [database executeUpdateWithSqlstatement:[NSString stringWithUpdateObject:model columns:columns]];
- }
- + (NSArray <__kindof FFDataBaseModel *>*)selectDBToClass:(Class)toClass
- SQLStatementWithFormat:(NSString *)format
- {
- FMDatabase *database = [self database];
- NSMutableArray *dataArray = [NSMutableArray array];
- NSArray *dataColumns = [toClass columnsOfSelf];
- if ([database open])
- {
- FMResultSet *resultSet;
- resultSet = [database 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];
- }
- [dataArray addObject:object];
- }
- }
- [database close];
- return dataArray;
- }
- + (BOOL)updateDBWithSQLStatementWithFormat:(NSString *)format
- {
- FMDatabase *database = [self database];
- return [database executeUpdateWithSqlstatement:format];
- }
- + (void)alterFromClass:(Class)dbClass
- columns:(NSArray <NSString *>*)columns
- {
- FMDatabase *database = [self database];
- NSString *tableName = [dbClass tableName];
- if (columns.count == 0)
- {
- columns = [dbClass columnsOfSelf];
- }
-
- if ([database open])
- {
-
- for (NSString *propertyname in columns)
- {
- if (![database columnExists:propertyname inTableWithName:tableName])
- {
- NSString *columnType = [[[dbClass class] columnsType][propertyname]length] == 0 ? @"text":[[dbClass class] columnsType][propertyname];
- [database executeUpdateWithSqlstatement:[NSString stringWithFormat:@"alter table `%@` add %@ %@",tableName,propertyname,columnType]];
- }
- }
- }
- [database close];
- }
- + (BOOL)createTableFromClass:(Class)dbClass
- {
- FMDatabase *database = [self database];
- return [database executeUpdateWithSqlstatement:[NSString stringWithCreateTableFromClass:dbClass]];
-
- }
- + (NSString *)databasePath
- {
- NSDictionary *infoDictionary = [[NSBundle mainBundle] infoDictionary];
- NSString *executableFile = [infoDictionary objectForKey:(NSString *)kCFBundleExecutableKey];
- NSString *datebaseName = [NSString stringWithFormat:@"%@.sqlite",executableFile];
- NSString *databasePath = [[NSSearchPathForDirectoriesInDomains( NSDocumentDirectory, NSUserDomainMask, YES) lastObject]stringByAppendingPathComponent:datebaseName];
- return databasePath;
- }
- + (FMDatabase *)database
- {
- FMDatabase *database = [FMDatabase databaseWithPath:[FFDBManager databasePath]];
- return database;
- }
- @end
|