我使用一個sqlite數據庫的項目。我可以做像SELECT這樣的查詢,但不可能做INSERT! 在模擬器上,INSERT正常工作。只要我在我的iPod上編譯,就會出現以下錯誤消息:「嘗試寫入只讀數據庫」。sqlite ios:試圖寫一個只讀數據庫
認爲這是一個文件的權利我做了一個:chmod 777 mydatabase.sqlite
但這並沒有改變!
我也試過,因爲我已經在其他網站上閱讀並複製該文件以使用他的副本來擁有它,但無濟於事。
你有解決方案嗎? 親切。
PS:這裏是我的代碼:
for(NSDictionary *q in quotes) {
sqlite3_stmt *statement;
sqlite3 *contactDB;
const char *dbpath = [dbPath UTF8String];
if (sqlite3_open_v2(dbpath, &contactDB, SQLITE_OPEN_READWRITE, NULL) == SQLITE_OK)
{
NSInteger identifiant = [[q objectForKey:@"id"] integerValue];
NSString *texte = [q objectForKey:@"texte_english"];
NSString *auteur = [q objectForKey:@"auteur"];
NSString *date = [q objectForKey:@"date"];
NSInteger auteurId = [[q objectForKey:@"auteur_id"] integerValue];
NSInteger nbComments = [[q objectForKey:@"nb_comments"] integerValue];
NSString *insertSQL =
[NSString stringWithFormat:@"INSERT INTO quotes (id, texte_english, auteur, date, auteur_id, nb_comments) VALUES (%d, \"%@\", \"%@\", \"%@\", \"%d\", \"%d\")",
identifiant,
texte,
auteur,
date,
auteurId,
nbComments];
const char *insert_stmt = [insertSQL UTF8String];
sqlite3_prepare_v2(contactDB, insert_stmt, -1, &statement, NULL);
if (sqlite3_step(statement) != SQLITE_DONE)
{
NSLog(@"ERREUR1: %s",sqlite3_errmsg(contactDB));
}
sqlite3_finalize(statement);
sqlite3_close(contactDB);
}
}
什麼是'dbpath'的價值? – 2012-08-17 05:40:42
什麼是dbPath?如果它是應用程序包內的路徑,則無法寫入該目錄。如果您使用種子數據庫,則需要將其複製到另一個目錄(如文檔),並且只能從該目錄實際打開。 – 2012-08-17 05:41:18
dbPath是:/var/mobile/Applications/E43E1EEC-3D82-4FD0-A5DC-61A3B173A22D/myapp.app/tq.sqlite – 2012-08-17 05:46:59