我不明白“为什么”SQLiteDB可能不会响应“-checkIfDatabaseExists”。这是什么原因造成的?我该如何解决? (我真的很接近这个工作,但因为我是一个新手,我仍然有问题)。这是什么原因造成的?
我很感激任何帮助,我可以得到这一点。下面是代码:
#import "SQLiteDB.h"
static SQLiteDB *sharedSQLiteDB = nil; // makes this a singleton class
@implementation SQLiteDB
@synthesize db, dbPath, databaseKey;
//-------------- check for database or create it ----------------|
#pragma mark Singleton Methods
+ (SQLiteDB *) sharedSQLiteDB {
if(!sharedSQLiteDB) {
sharedSQLiteDB = [[SQLiteDB alloc] init];
[sharedSQLiteDB checkIfDatabaseExists];
}
return sharedSQLiteDB;
}
+(id)allocWithZone:(NSZone *)zone {
if(!sharedSQLiteDB) {
sharedSQLiteDB = [super allocWithZone:zone];
return sharedSQLiteDB;
}
else {
return nil;
}
}
-(id)copyWithZone:(NSZone *)zone {
return self;
}
-(void) release {
// no-op
}
- (void) checkIfDatabaseExists {
// Get the path to the database file
NSArray *searchPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentPath = [searchPaths objectAtIndex:0];
NSString *databasePath = [documentPath stringByAppendingPathComponent:@"ppcipher.s3db"];
// Open the database file
const char *cDatabasePath = [databasePath cStringUsingEncoding:NSUTF8StringEncoding];
if(sqlite3_open(cDatabasePath, &db) == SQLITE_OK) // does it exist?
return;
else { // create database file here
}
}
@end
请将代码粘贴为文本,而不仅仅是截图。 – mkb 2011-03-10 16:37:45
当然......为什么还要写另一个数据库封装(如果这是你在做什么)?核心数据是在iOS/Mac OS X上创建数据库的最佳支持和最佳性能(无需巨大的工程努力)。如果您需要打包任意模式的SQLite数据库,FMDB似乎是一条可行的路。 – bbum 2011-03-10 17:04:37