iOS SQLite 文件保存不持久
<p><p>我正在开发 Xcode 6,Objective-C。我正在尝试使用 SQLite 来存储我的数据。但是我有一个问题,存储不是持久的。
当我启动我的程序时,我的数据库文件中有这个:</p>
<blockquote>
<p>id = 0; money = 1000000; name = xx;</p>
<p>id = 1; money = 500200; name = bb;</p>
</blockquote>
<p>现在,当我在表中插入新数据并检查我有 3 行时。但是当我关闭我的应用程序并重新打开它时,我仍然有 2 行。 </p>
<p>这是一些代码,这是我的初始化函数:</p>
<pre><code>- (id)init {
self = ;
if (self){
;
if (sqlite3_open([[ stringByAppendingPathComponent:@"Bank.sqlite"]UTF8String],
&_database) != SQLITE_OK) {
NSLog(@"Failed to open database!");
}
}
return self;
}
</code></pre>
<p>这是我的插入函数:</p>
<pre><code>-(void)insert:(NSString *)cols withValues:(NSString *)values into:(NSString *) table{
NSString *query = ;
sqlite3_stmt *statement;
if (sqlite3_prepare_v2(_database, , -1, &statement, nil) == SQLITE_OK) {
while (sqlite3_step(statement) == SQLITE_DONE);
sqlite3_finalize(statement);
}else{
NSLog(@"Failed to delete!");
sqlite3_errmsg(_database);
}
}
</code></pre>
<p>感谢您的帮助。</p></p>
<br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
<p><p><code>;</code></p>
<p>看起来您每次初始化该对象时都将数据库从 bundle 复制到文档目录。因此,当您再次启动应用程序时,您将覆盖您的数据库。</p>
<p>如果数据库不存在,您只想复制它。</p></p>
<p style="font-size: 20px;">关于iOS SQLite 文件保存不持久,我们在Stack Overflow上找到一个类似的问题:
<a href="https://stackoverflow.com/questions/30218957/" rel="noreferrer noopener nofollow" style="color: red;">
https://stackoverflow.com/questions/30218957/
</a>
</p>
页:
[1]