J'ai une base de données sqlite et j'y ajoute de nouveaux mots. Le problème est que je peux les voir ajoutés à une table seulement après le redémarrage de l'application. L'instruction "SELECT" ne "voit" pas les éléments nouvellement ajoutés avant de redémarrer l'application.Base de données SQLite - ne peut pas voir les mises à jour
Pourquoi cela est-il possible? Je crée une sorte de dictionnaire. Voici comment ajouter de nouveaux éléments:
const char *sql_query = "INSERT INTO words(word) VALUES(?)";
if(sqlite3_prepare_v2(database, sql_query, -1, &addWordsStmt, NULL) != SQLITE_OK)
{
return FALSE;
}
sqlite3_bind_text(addWordsStmt, 1, [ word UTF8String], -1, SQLITE_TRANSIENT);
if(sqlite3_step(addWordsStmt) != SQLITE_DONE)
NSAssert1(0, @"Error while inserting data. '%s'", sqlite3_errmsg(database));
sqlite3_reset(addWordsStmt);
sqlite3_finalize(addWordsStmt);
Et voici mon code de récupération:
const char *sql_query = "SELECT word FROM words WHERE id=?";
if(sqlite3_prepare_v2(database, sql_query, -1, &getWordsStmt, NULL) != SQLITE_OK)
{
return;
}
sqlite3_bind_int(getWordsStmt, 1, wordid);
if(sqlite3_step(getWordsStmt) != SQLITE_ROW)
{
NSLog(@"Error while getting data. '%s'", sqlite3_errmsg(database));
sqlite3_reset(getWordsStmt);
return;
}
NSString *word = [NSString stringWithUTF8String:(char *)sqlite3_column_text(getWordsStmt, 0)];
sqlite3_reset(getWordsStmt);
sqlite3_finalize(getWordsStmt);
Comment ajoutez-vous les mots? Comment les cherchez-vous? Montrez-nous la source! –
Je voudrais essayer NSLogging le résultat de chaque appel sqlite3_ unique, pour voir tout est prévu, mais votre code d'ajout semble que cela devrait probablement fonctionner. À quoi ressemble votre source de récupération? –