FMDatabase.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. #import <Foundation/Foundation.h>
  2. #import "sqlite3.h"
  3. #import "FMResultSet.h"
  4. @interface FMDatabase : NSObject
  5. {
  6. sqlite3* db;
  7. NSString* databasePath;
  8. BOOL logsErrors;
  9. BOOL crashOnErrors;
  10. BOOL inUse;
  11. BOOL inTransaction;
  12. BOOL traceExecution;
  13. BOOL checkedOut;
  14. int busyRetryTimeout;
  15. BOOL shouldCacheStatements;
  16. NSMutableDictionary *cachedStatements;
  17. }
  18. + (id)databaseWithPath:(NSString*)inPath;
  19. - (id)initWithPath:(NSString*)inPath;
  20. - (BOOL)open;
  21. #if SQLITE_VERSION_NUMBER >= 3005000
  22. - (BOOL)openWithFlags:(int)flags;
  23. #endif
  24. - (BOOL)close;
  25. - (BOOL)goodConnection;
  26. - (void)clearCachedStatements;
  27. // encryption methods. You need to have purchased the sqlite encryption extensions for these to work.
  28. - (BOOL)setKey:(NSString*)key;
  29. - (BOOL)rekey:(NSString*)key;
  30. - (NSString *)databasePath;
  31. - (NSString*)lastErrorMessage;
  32. - (int)lastErrorCode;
  33. - (BOOL)hadError;
  34. - (sqlite_int64)lastInsertRowId;
  35. - (sqlite3*)sqliteHandle;
  36. - (BOOL)update:(NSString*)sql error:(NSError**)outErr bind:(id)bindArgs, ...;
  37. - (BOOL)executeUpdate:(NSString*)sql, ...;
  38. - (BOOL)executeUpdate:(NSString*)sql withArgumentsInArray:(NSArray *)arguments;
  39. - (BOOL)executeUpdate:(NSString*)sql error:(NSError**)outErr withArgumentsInArray:(NSArray*)arrayArgs orVAList:(va_list)args; // you shouldn't ever need to call this. use the previous two instead.
  40. - (FMResultSet *)executeQuery:(NSString*)sql, ...;
  41. - (FMResultSet *)executeQuery:(NSString *)sql withArgumentsInArray:(NSArray *)arguments;
  42. - (FMResultSet *)executeQuery:(NSString *)sql withArgumentsInArray:(NSArray*)arrayArgs orVAList:(va_list)args; // you shouldn't ever need to call this. use the previous two instead.
  43. - (BOOL)rollback;
  44. - (BOOL)commit;
  45. - (BOOL)beginTransaction;
  46. - (BOOL)beginDeferredTransaction;
  47. - (BOOL)logsErrors;
  48. - (void)setLogsErrors:(BOOL)flag;
  49. - (BOOL)crashOnErrors;
  50. - (void)setCrashOnErrors:(BOOL)flag;
  51. - (BOOL)inUse;
  52. - (void)setInUse:(BOOL)value;
  53. - (BOOL)inTransaction;
  54. - (void)setInTransaction:(BOOL)flag;
  55. - (BOOL)traceExecution;
  56. - (void)setTraceExecution:(BOOL)flag;
  57. - (BOOL)checkedOut;
  58. - (void)setCheckedOut:(BOOL)flag;
  59. - (int)busyRetryTimeout;
  60. - (void)setBusyRetryTimeout:(int)newBusyRetryTimeout;
  61. - (BOOL)shouldCacheStatements;
  62. - (void)setShouldCacheStatements:(BOOL)value;
  63. - (NSMutableDictionary *)cachedStatements;
  64. - (void)setCachedStatements:(NSMutableDictionary *)value;
  65. + (NSString*)sqliteLibVersion;
  66. - (int)changes;
  67. @end
  68. @interface FMStatement : NSObject {
  69. sqlite3_stmt *statement;
  70. NSString *query;
  71. long useCount;
  72. }
  73. - (void)close;
  74. - (void)reset;
  75. - (sqlite3_stmt *)statement;
  76. - (void)setStatement:(sqlite3_stmt *)value;
  77. - (NSString *)query;
  78. - (void)setQuery:(NSString *)value;
  79. - (long)useCount;
  80. - (void)setUseCount:(long)value;
  81. @end