SQLite相关异常

Posted on 2018-08-02 16:20  TongMeng  阅读(1316)  评论(0编辑  收藏  举报

SQLite的异常大多都和异常IO操作有关,这类异常通常在debug测试的时候难以发现通常和用户的操作有关系,根据我遇到的包括以下几种:

1.No transaction is active

 这种情况通常是批量插入数据(for+insert)大量数据时会产生。因为android默认插入数据的时候默认一条语句就是一个事务,有多少数据就会进行多少次磁盘操作,而且不能保障所有数据能够同时插入。可以这样写

try{

   for(String sql:sqls){
     
       db.execSQL(sql);
    }  
    //设置事务标识,结束事务时会提交事务
    db.setTransactionSuccessful(); 
}catch (Exception e) {
    e.printStackTrace();
   }

  setTransactionSuccessful()这个方法在执行前,所有的execSQL都不会更新到数据库,当这个方法执行完后会一次性写入所有execSQL方法,数据同步更新到数据库。

2.忘记关闭游标(Cursor window allocation of 2084 kb failed)

  这个异常是因为查询后忘记关闭cursor,内存泄漏多了就崩溃了,解决办法自然是手动关闭cursor;

3.数据库被锁定(database is locked)

  当我们在不同的线程创建多个连接时,就会抛出这个异常,解决方法是把db做成一个单例对象,或者使用contentprovider

4.试图打开已经关闭的对象 (attempt to reopen an already-closed object)

    这个问题实际上是3的延续,既然做成了单例,如果在不同的线程中创建多个连接,就会报当期的错误信息。频繁的操作SQlite数据库容易产生此异常,解决办法就是在统一的地方进行数据库的打开和关闭,比如在页面销毁时再关闭连接。