0

当我将android版本和路径从externalized更改为默认数据库文件夹时,我不知道错误来自哪里。我发现原因可能是访问日志文件的问题被锁定(它是由程序创建的)。

“测试”正在读取数据,如果存在则更新,如果不存在则插入。这是在从文件中读取行时循环完成的。出于测试目的,我对其进行了简化,但错误是相同的。

package ...;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
public class test {
    public test(SQLiteDatabase MyDB)
    {
        MyDB.execSQL("CREATE TABLE IF NOT EXISTS testtable (mytext TEXT, number INT PRIMARY KEY)", new String[] {});
        for (int i = 1; i < 5; i++)
        {
            String[] ColArray = { "any text", String.valueOf(i) };
            Cursor readCursor = MyDB.rawQuery("SELECT mytext FROM testtable WHERE number=?", new String[] { String.valueOf(i) });
            if (!readCursor.moveToNext()) // Error when executing moveToNext
/*
    In the 2nd time it runs over this point an Error occurs:
    android.database.sqlite.SQLiteCantOpenDatabaseException: unable to open database file (code 14)
    I need to remove the journal file to be able to connect to the database it again - the change made by the Insert/Update is successfully saved!
*/          {
                readCursor.close();
                MyDB.execSQL("INSERT INTO testtable (mytext, number) VALUES(?, ?)", ColArray);
            }
            else {
                readCursor.close();
                MyDB.execSQL("UPDATE testtable SET mytext=? WHERE number=?", ColArray);
            }
        }
    }
}

MyDB 是一个有效的 DB-Connection。1) 表已创建 2) 表已读取但未找到第 1 行 2a) 如果读取已关闭,则到现在为止可以再次读取。3) 第 1 行已插入 4) 再次尝试 READ 时(也找不到第 2 行),移动光标失败。

日志文件需要手动删除,否则在尝试连接时应用程序将无法重新启动。

请帮忙!谢谢你。

4

2 回答 2

0

经过数小时的测试,我解决了它。

可能新旧系统中的sqlite版本不同...我再次更改了rom-出于某种原因,这次我没有将数据库文件复制到数据文件夹中。相反,我让程序创建一个空数据库,并由程序本身从 csv 导出中导入文本数据。

我目前不知道问题是否在 rom 内,或者(我认为原因似乎是什么)我通过使用原始数据库创建了问题,该数据库可能是可读写的,但在处理日志文件时会出现问题。如果有人有同样的问题,他应该尝试在新系统中创建一个新的空数据库。

于 2015-09-27T22:48:10.817 回答
0

也许您应该使用专门的插入和更新方法。

SQLiteDatabase的文档中,它对 execSQL 说:

执行不是 SELECT/INSERT/UPDATE/DELETE 的单个 SQL 语句。

有用于插入和更新的专用方法,具有相似的名称。我想,当使用不特定的“execSQL”语句时会产生一些问题。

于 2015-09-26T17:24:17.093 回答