SQLiteCantOpenDatabaseException: unable to open database file

在操作android中的sqlite数据库的时候,因为频繁的查询导致数据库在跑了一分多钟突然程序崩了报了这个错误,如下:

  android.database.sqlite.SQLiteCantOpenDatabaseException: unable to open database file (code 14)
        at android.database.sqlite.SQLiteConnection.nativeExecuteForLastInsertedRowId(Native Method)
        at android.database.sqlite.SQLiteConnection.executeForLastInsertedRowId(SQLiteConnection.java:791)
        at android.database.sqlite.SQLiteSession.executeForLastInsertedRowId(SQLiteSession.java:788)
        at android.database.sqlite.SQLiteStatement.executeInsert(SQLiteStatement.java:86)
        at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1529)
        at android.database.sqlite.SQLiteDatabase.replace(SQLiteDatabase.java:1445)
        at com.mob.commons.logcollector.b.a(DBProvider.java:57)
        at com.mob.commons.logcollector.e.a(MessageUtils.java:30)
        at com.mob.commons.logcollector.c$2.run(LogsManager.java:203)
        at com.mob.commons.e.a(Locks.java:109)
        at com.mob.commons.e.a(Locks.java:43)
        at com.mob.commons.logcollector.c.d(LogsManager.java:198)
        at com.mob.commons.logcollector.c.a(LogsManager.java:136)
        at com.mob.commons.logcollector.c$1.handleMessage(LogsManager.java:66)
        at android.os.Handler.dispatchMessage(Handler.java:107)
        at android.os.Looper.loop(Looper.java:224)
        at com.mob.tools.MobHandlerThread.run(MobHandlerThread.java:56)
        at com.mob.tools.MobHandlerThread$1.run(MobHandlerThread.java:136)

在查了一些博客以后发现问题是由于查询后生成的Cursor对象没有关闭导致的在对应的地方调用一下cursor.close();方法后正常,在相同的情况下测试了20多分钟,一切正常

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值