ee9163cee7825c6ac7ce0a240fed15d3d459b471
[ITFoundation.git] / ITSQLite3Database.h
1 /*
2  *      ITFoundation
3  *      ITSQLite3Database.h
4  *
5  *      Copyright (c) 2008 by iThink Software.
6  *      All Rights Reserved.
7  *
8  *      $Id$
9  *
10  */
11
12 #import <Foundation/Foundation.h>
13 #import <sqlite3.h>
14
15 extern int sqlite3_bind_objc_object(sqlite3_stmt *statement, int index, id object);
16 extern id sqlite3_column_objc_object(sqlite3_stmt *statement, int columnIndex);
17
18 @interface ITSQLite3Database : NSObject {
19         NSString *dbPath;
20         sqlite3 *db;
21         NSRecursiveLock *dbLock;
22 }
23
24 - (id)initWithPath:(NSString *)path;
25
26 - (BOOL)begin;
27 - (BOOL)beginTransaction;
28 - (BOOL)commit;
29 - (BOOL)commitTransaction;
30 - (BOOL)rollback;
31 - (BOOL)rollbackTransaction;
32
33 - (BOOL)executeQuery:(NSString *)query, ...;
34
35 // returns a dictionary with column names as keys, or nil
36 - (NSDictionary *)fetchRow:(NSString *)query, ...;
37
38 // returns an array of dictionaries with column names as keys, or an empty array
39 - (NSArray *)fetchTable:(NSString *)query, ...;
40
41 // returns a single column value, or nil
42 - (id)fetchRowColumn:(NSString *)query, ...;
43
44 // returns an array of single column values, or an empty array
45 - (NSArray *)fetchTableColumn:(NSString *)query, ...;
46
47 @end