FFDBManager.m 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. //
  2. // FFDBManager.m
  3. // FFDB
  4. //
  5. // Created by Fidetro on 2017/5/11.
  6. // Copyright © 2017年 Fidetro. All rights reserved.
  7. //
  8. // https://github.com/Fidetro/FFDB
  9. #import "FFDBManager.h"
  10. #import "FFDataBaseModel+Sqlite.h"
  11. #import "NSObject+FIDProperty.h"
  12. #import "NSString+FFDBSQLStatement.h"
  13. #import "FFDataBaseModel+Custom.h"
  14. #import "FMDatabase+FFExtern.h"
  15. @implementation FFDBManager
  16. + (NSArray *)selectColumns:(NSArray <NSString *>*)columns
  17. fromClass:(Class)dbClass
  18. SQLStatementWithFormat:(NSString *)format
  19. {
  20. FMDatabase *database = [self database];
  21. NSArray *dataColumns = [NSArray array];
  22. NSMutableArray *dataArray = [NSMutableArray array];
  23. if (columns.count == 0)
  24. {
  25. dataColumns = [dbClass columnsOfSelf];
  26. }
  27. else
  28. {
  29. dataColumns = columns;
  30. }
  31. if ([database open])
  32. {
  33. FMResultSet *resultSet;
  34. resultSet = [database executeQuery:[NSString stringWithSelectColumns:columns fromClasses:@[dbClass] SQLStatementWithFormat:format]];
  35. while ([resultSet next])
  36. {
  37. id object = [[dbClass alloc]init];
  38. for (NSString *propertyname in dataColumns)
  39. {
  40. NSString *result = [resultSet stringForColumn:propertyname];
  41. NSString *objStr = [result length] == 0 ? @"" :result;
  42. [object setPropertyWithName:propertyname object:objStr];
  43. }
  44. [object setPropertyWithName:@"primaryID" object:[resultSet stringForColumn:@"primaryID"]];
  45. [dataArray addObject:object];
  46. }
  47. }
  48. [database close];
  49. return dataArray;
  50. }
  51. + (long long int)selectCountfromClasses:(NSArray <Class>*)dbClasses
  52. SQLStatementWithFormat:(NSString *)format
  53. {
  54. FMDatabase *database = [self database];
  55. long long int totalCount = 0;
  56. if ([database open])
  57. {
  58. FMResultSet *resultSet;
  59. resultSet = [database executeQuery:[NSString stringWithSelectCountfromClasses:dbClasses SQLStatementWithFormat:format]];
  60. while ([resultSet next])
  61. {
  62. totalCount = [resultSet longLongIntForColumnIndex:0];
  63. }
  64. }
  65. [database close];
  66. return totalCount;
  67. }
  68. + (NSArray <__kindof FFDataBaseModel *>*)selectColumns:(NSArray <NSString *>*)columns
  69. fromClasses:(NSArray<Class> *)dbClasses
  70. toClass:(Class)toClass
  71. SQLStatementWithFormat:(NSString *)format
  72. {
  73. NSString *SQLStatement = [NSString stringWithSelectColumns:columns fromClasses:dbClasses SQLStatementWithFormat:format];
  74. NSArray *dataArray = [self selectDBToClass:toClass SQLStatementWithFormat:SQLStatement];
  75. return dataArray;
  76. }
  77. + (BOOL)deleteFromClass:(Class)dbClass
  78. SQLStatementWithFormat:(NSString *)format
  79. {
  80. FMDatabase *database = [self database];
  81. return [database executeUpdateWithSqlstatement:[NSString stringWithDeleteFromClass:dbClass SQLStatementWithFormat:format]];
  82. }
  83. + (BOOL)insertObject:(__kindof FFDataBaseModel *)model
  84. columns:(NSArray <NSString *>*)columns
  85. {
  86. FMDatabase *database = [self database];
  87. return [database executeUpdateWithSqlstatement:[NSString stringWithInsertObject:model columns:columns]];
  88. }
  89. + (BOOL)updateFromClass:(Class)dbClass
  90. SQLStatementWithFormat:(NSString *)format
  91. {
  92. FMDatabase *database = [self database];
  93. return [database executeUpdateWithSqlstatement:[NSString stringWithUpdateFromClass:dbClass SQLStatementWithFormat:format]];
  94. }
  95. + (BOOL)updateObject:(__kindof FFDataBaseModel *)model
  96. columns:(NSArray <NSString *>*)columns
  97. {
  98. FMDatabase *database = [self database];
  99. return [database executeUpdateWithSqlstatement:[NSString stringWithUpdateObject:model columns:columns]];
  100. }
  101. + (NSArray <__kindof FFDataBaseModel *>*)selectDBToClass:(Class)toClass
  102. SQLStatementWithFormat:(NSString *)format
  103. {
  104. FMDatabase *database = [self database];
  105. NSMutableArray *dataArray = [NSMutableArray array];
  106. NSArray *dataColumns = [toClass columnsOfSelf];
  107. if ([database open])
  108. {
  109. FMResultSet *resultSet;
  110. resultSet = [database executeQuery:format];
  111. while ([resultSet next])
  112. {
  113. id object = [[toClass alloc]init];
  114. for (NSString *propertyname in dataColumns)
  115. {
  116. NSString *result = [resultSet stringForColumn:propertyname];
  117. NSString *objStr = [result length] == 0 ? @"" :result;
  118. [object setPropertyWithName:propertyname object:objStr];
  119. }
  120. [dataArray addObject:object];
  121. }
  122. }
  123. [database close];
  124. return dataArray;
  125. }
  126. + (BOOL)updateDBWithSQLStatementWithFormat:(NSString *)format
  127. {
  128. FMDatabase *database = [self database];
  129. return [database executeUpdateWithSqlstatement:format];
  130. }
  131. + (void)alterFromClass:(Class)dbClass
  132. columns:(NSArray <NSString *>*)columns
  133. {
  134. FMDatabase *database = [self database];
  135. NSString *tableName = [dbClass tableName];
  136. if (columns.count == 0)
  137. {
  138. columns = [dbClass columnsOfSelf];
  139. }
  140. if ([database open])
  141. {
  142. for (NSString *propertyname in columns)
  143. {
  144. if (![database columnExists:propertyname inTableWithName:tableName])
  145. {
  146. NSString *columnType = [[[dbClass class] columnsType][propertyname]length] == 0 ? @"text":[[dbClass class] columnsType][propertyname];
  147. [database executeUpdateWithSqlstatement:[NSString stringWithFormat:@"alter table `%@` add %@ %@",tableName,propertyname,columnType]];
  148. }
  149. }
  150. }
  151. [database close];
  152. }
  153. + (BOOL)createTableFromClass:(Class)dbClass
  154. {
  155. FMDatabase *database = [self database];
  156. return [database executeUpdateWithSqlstatement:[NSString stringWithCreateTableFromClass:dbClass]];
  157. }
  158. + (NSString *)databasePath
  159. {
  160. NSDictionary *infoDictionary = [[NSBundle mainBundle] infoDictionary];
  161. NSString *executableFile = [infoDictionary objectForKey:(NSString *)kCFBundleExecutableKey];
  162. NSString *datebaseName = [NSString stringWithFormat:@"%@.sqlite",executableFile];
  163. NSString *databasePath = [[NSSearchPathForDirectoriesInDomains( NSDocumentDirectory, NSUserDomainMask, YES) lastObject]stringByAppendingPathComponent:datebaseName];
  164. return databasePath;
  165. }
  166. + (FMDatabase *)database
  167. {
  168. FMDatabase *database = [FMDatabase databaseWithPath:[FFDBManager databasePath]];
  169. return database;
  170. }
  171. @end