SQLite返回错误代码14

Kis*_*ore 16 database android android-sqlite

我正在尝试从我的资源文件夹中复制现有数据库并对其执行一些操作.一切正常,但我的模拟器的日志文件中出现以下错误:

sqlite returned: error code = 14, msg = cannot open file at source line 25467

09-06 11:23:41.844: INFO/Database(22560): sqlite returned: error code = 14, msg = cannot open file at source line 25467
09-06 11:23:41.885: ERROR/Database(22560): sqlite3_open_v2("/data/data/com.dhani.Lazy/databases/LazyDB.sqlite", &handle, 1, NULL) failed
09-06 11:23:41.885: WARN/System.err(22560): android.database.sqlite.SQLiteException: unable to open database file
09-06 11:23:41.894: WARN/System.err(22560):     at android.database.sqlite.SQLiteDatabase.dbopen(Native Method)
09-06 11:23:41.904: WARN/System.err(22560):     at android.database.sqlite.SQLiteDatabase.<init>(SQLiteDatabase.java:1849)
09-06 11:23:41.914: WARN/System.err(22560):     at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:820)
09-06 11:23:41.914: WARN/System.err(22560):     at com.dharani.LazyApple.Database.DataBaseHelper.checkDataBase(DataBaseHelper.java:72)
09-06 11:23:41.914: WARN/System.err(22560):     at com.dharani.LazyApple.Database.DataBaseHelper.createDataBase(DataBaseHelper.java:47)
09-06 11:23:41.914: WARN/System.err(22560):     at com.dharani.LazyApple.Database.DataBaseHelper.Login(DataBaseHelper.java:166)
09-06 11:23:41.914: WARN/System.err(22560):     at com.dharani.LazyApple.Views.LoginView$1.onClick(LoginView.java:63)
09-06 11:23:41.934: WARN/System.err(22560):     at android.view.View.performClick(View.java:2485)
09-06 11:23:41.934: WARN/System.err(22560):     at android.view.View$PerformClick.run(View.java:9080)
09-06 11:23:41.944: WARN/System.err(22560):     at android.os.Handler.handleCallback(Handler.java:587)
09-06 11:23:41.944: WARN/System.err(22560):     at android.os.Handler.dispatchMessage(Handler.java:92)
09-06 11:23:41.944: WARN/System.err(22560):     at android.os.Looper.loop(Looper.java:123)
09-06 11:23:41.944: WARN/System.err(22560):     at android.app.ActivityThread.main(ActivityThread.java:3683)
09-06 11:23:41.964: WARN/System.err(22560):     at java.lang.reflect.Method.invokeNative(Native Method)
09-06 11:23:41.964: WARN/System.err(22560):     at java.lang.reflect.Method.invoke(Method.java:507)
09-06 11:23:41.964: WARN/System.err(22560):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
09-06 11:23:41.964: WARN/System.err(22560):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
09-06 11:23:41.964: WARN/System.err(22560):     at dalvik.system.NativeStart.main(Native Method)
Run Code Online (Sandbox Code Playgroud)

有关如何解决这个问题的任何建议?

小智 8

这可能有点晚了,但希望这有助于谁遇到这个问题(因为我无法找到明确的解决方案).

我想我知道这个原因的原因(至少在我的情况下).查看DDMS - >文件资源管理器,您会发现 数据库文件夹(/ data/data // databases /)不存在,这就是应用程序无法在该不存在的文件夹中创建数据库文件的原因.如果您可以以某种方式创建数据库文件夹,则可以避免此问题.

因为我很懒,所以当我处于模拟器模式时,我只使用了/ data/data // files /文件夹.您可以使用以下方法获取文件目录:

context.getFilesDir().getPath()
Run Code Online (Sandbox Code Playgroud)

这在模拟器中对我来说非常漂亮.

希望这有助于某人.

如果你想看到一些代码:

String dbFilename = "example.db";
try
{       
    File databaseFile = getDatabasePath(dbFilename);        
        SQLiteDatabase _db = SQLiteDatabase.openOrCreateDatabase(databaseFile);
} catch (Exception e)
{
    String databasePath =  getFilesDir().getPath() +  "/" + dbFilename;
    File databaseFile = new File(databasePath); 
    _db = SQLiteDatabase.openOrCreateDatabase(databaseFile);
}
Run Code Online (Sandbox Code Playgroud)

编辑:我尝试登录到模拟器上的Facebook(我的应用程序有FB集成)和/之后出现的/ databases文件夹(并保持).不确定发生了什么,但有可能以某种方式创建该文件夹.在这里为另一位专家提供了解决方案.


Nic*_*ong 6

我已经看到如果您在清单中使用sharedUserId会发生此错误.如果更改应用程序的sharedUserId并重新安装应用程序,则它没有写入SQLite数据库所需的所有权.

  • 嗨基肖尔你做了什么改变?我也遇到同样的问题.... (4认同)

小智 6

今天这个问题花了我3个小时.我尝试了什么:

  • 重写复制数据库代码.
  • 从模拟器/设备中删除应用程序
  • 擦除模拟器
  • 清洁日食
  • 更改文件权限

我通过将代码从共享的Dropbox帐户复制到另一个位置并使用另一个包名重构Android Manifest和java文件中的代码来解决了这个问题.

该应用程序现在运行得很漂亮.

  • 听起来你只需要干净就可以节省一些时间. (6认同)

Ste*_*Bra 6

我有同样的问题.

什么解决了,正在取代

private static String DB_PATH = "/data/data/YOUR_PACKAGE/databases/";
Run Code Online (Sandbox Code Playgroud)

String myPath = myContext.getFilesDir().getAbsolutePath().replace("files",
"databases")+File.separator + DB_NAME;
Run Code Online (Sandbox Code Playgroud)