当前位置:  开发笔记 > 数据库 > 正文

在多个Android活动之间共享sqlite数据库

如何解决《在多个Android活动之间共享sqlite数据库》经验,为你挑选了1个好方法。

两个或多个Android活动可以打开一个sqlite3数据库进行写入吗?

我有两个活动需要将数据插入到同一个sqlite数据库中.当第二个Activity调用时SQLiteOpenHelper.getWriteableDatabase()抛出IllegalStateException,并显示消息" SQLiteDatabase created and never closed ".

我已经能够通过使我的数据库对象成为单例来避免异常,但我认为必须有更好的方法.

谢谢,

约翰



1> Jeremy Logan..:

一次运行的活动永远不会超过一个.解决这个问题的简单方法是让第一个Activity在启动第二个Activity之前关闭它的连接.你可以在onPause()中执行此操作,然后在onResume()中重新打开它.像这样的东西(很伪的代码):

MyActivity {
    OnResume()
        open connection to database
    OnPause()
        close connection to database
}

这样,您永远不会尝试一次连接多个连接,并且连接始终可用.


我一直想知道这种方法是否比让活动使用相同的单例对象更好.我认为这是因为这种方法在暂停活动时使连接成为正确的状态.使用单例连接会导致有问题的清理.谢谢.
我在六个应用程序中成功使用了这个模式.如果你遇到问题,你必须做一些有趣的事情.提出问题并发布代码.
推荐阅读
手机用户2502851955
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有