0

私のviewDidLoad()には以下のコードがあります:

// Create a string containing the full path to the sqlite.db inside the documents folder
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *databasePath = [documentsDirectory stringByAppendingPathComponent:@"sqlite.db"];

// Check to see if the database file already exists
bool databaseAlreadyExists = [[NSFileManager defaultManager] fileExistsAtPath:databasePath];

// Open the database and store the handle as a data member
if (sqlite3_open([databasePath UTF8String], &databaseHandle) == SQLITE_OK)
{
    // Create the database if it doesn't yet exists in the file system
    if (!databaseAlreadyExists)
    {
        // Create the PERSON table
        const char *sqlStatement = "CREATE TABLE IF NOT EXISTS PERSON (ID INTEGER PRIMARY KEY AUTOINCREMENT, FIRSTNAME TEXT, LASTNAME TEXT, BIRTHDAY DATE)";
        char *error;
        if (sqlite3_exec(databaseHandle, sqlStatement, NULL, NULL, &error) == SQLITE_OK)
        {
            // Create the ADDRESS table with foreign key to the PERSON table
            sqlStatement = "CREATE TABLE IF NOT EXISTS ADDRESS (ID INTEGER PRIMARY KEY AUTOINCREMENT, STREETNAME TEXT, STREETNUMBER INT, PERSONID INT, FOREIGN KEY(PERSONID) REFERENCES PERSON(ID))";
            if (sqlite3_exec(databaseHandle, sqlStatement, NULL, NULL, &error) == SQLITE_OK)
            {
                NSLog(@"Database and tables created.");
            }
            else
            {
                NSLog(@"Error: %s", error);
            }
        }
        else
        {
            NSLog(@"Error: %s", error);
        }
    }
}

sqlite3_close(databaseHandle);

そして、両方のテーブルが/ Users / * / Library / Application Support / iPhone Simulator / 5.1 / Applications / * /Documents/フォルダーに作成されることを期待しています。

しかし、そのフォルダーに移動してsqlite3と.schemaと入力すると、何も表示されません。しかし、sqlite.dbがそのフォルダーに作成されていることはわかりました。

なぜなのかご存知ですか?

4

1 に答える 1

0

db をコピーした後、プログラムでテーブルを作成します..確実に機能します!!!!

于 2013-02-02T07:26:52.800 に答える