首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >显示正在升级android数据库,请稍候

显示正在升级android数据库,请稍候
EN

Stack Overflow用户
提问于 2015-07-10 23:14:25
回答 1查看 416关注 0票数 0

我想在下一次更新中升级我的数据库,但我遇到了一个问题。我的升级太重,在设备上花费2-3分钟(取决于设备的硬件),它包含删除一些表创建表和将数据从旧表移动到新表,我不希望用户在升级时看到白屏,由于数据库升级是第一个运行的命令,我无法启动任何活动,请等待或任何其他数据。

为了解决这个问题,我使用了AsyncTask类,在数据库的onUpgrade中,我执行了一个asyncTask类来进行升级,我可以启动我的闪屏来通知用户应用程序需要一些时间。但是有了这个解决方案,我失去了事务性行为,如果设备被关闭,或者应用程序被终止,我的应用程序将面临更大的问题。

我知道如何在Transactional中运行我的多个代码,但据我所知,数据库版本已经提高,下次我启动应用程序时,数据库不再升级,应用程序也不再工作。(因为新表不存在)。

我想一个解决方案是跟踪我的升级数据库并保存到sharedPref中,在下一次启动时检查sharedPreference中的值,如果升级已经完成,让用户使用应用程序,否则完成升级过程。

我不认为这是最好的方法,所以我想问你,有没有其他解决方案可以在后台升级数据库,如果问题发生,数据库升级重新开始?

提前感谢,并感谢您的时间。

PS:我知道如果在onUpgrade中发生了任何错误,数据库升级会重新开始,但当我从UI线程升级到后台线程时,这种情况就不再发生了,我也不知道为什么。

EN

回答 1

Stack Overflow用户

发布于 2015-07-11 01:53:18

首先,我没有足够的名气来评论,这就是我写这个答案的原因。

为什么不在服务器端这样做呢?使用任何服务器端脚本语言,只要在升级数据库时锁定数据库,如果用户试图访问数据库,就会显示一条消息“当前某某正在维护中:几分钟后再来”。

这样你就不会干扰用户的工作,用户也不会在几分钟内回来。

我认为这在速度和可靠性上都比使用sharedPreference更好。

希望这能有所帮助。如果你在这方面需要任何帮助,请发表评论。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31344366

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档