Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在Android上升级应用程序后如何更新表架构?_Android_Sqlite_Upgrade_Database - Fatal编程技术网

在Android上升级应用程序后如何更新表架构?

在Android上升级应用程序后如何更新表架构?,android,sqlite,upgrade,database,Android,Sqlite,Upgrade,Database,我有一个未完成的应用程序,但我想现在解决它的未来更新 假设我的应用程序已升级,因此启动时会检测到数据库架构已过时。因此,对于每个表,必须根据新模式的版本号进行更新,同时保留所有数据 我在某个地方读到过,Android上的SQLite数据库有一些版本号和自动更新的东西,但我没有找到这个特定问题的例子 如何使用SQLite数据库在Android应用程序上实现这一点 Android SQLite数据库中存储的每个表是否有特定的版本号?如果是这样的话,我如何阅读它,并将其用于我的上述目的?是您的朋友 您

我有一个未完成的应用程序,但我想现在解决它的未来更新

假设我的应用程序已升级,因此启动时会检测到数据库架构已过时。因此,对于每个表,必须根据新模式的版本号进行更新,同时保留所有数据

我在某个地方读到过,Android上的SQLite数据库有一些版本号和自动更新的东西,但我没有找到这个特定问题的例子

如何使用SQLite数据库在Android应用程序上实现这一点

Android SQLite数据库中存储的每个表是否有特定的版本号?如果是这样的话,我如何阅读它,并将其用于我的上述目的?

是您的朋友


您需要提供
onCreate
onUpgrade
方法。

如何保存旧记录?记事本onUpgrade方法未指定此项。另外,我如何检测特定的表是否只需要更新?您可以使用ALTERTABLE语句或temp表来保留旧记录,就像任何SQL数据库一样。Android只会帮助告诉您您的整体架构是否发生了变化——这取决于您确定哪些表等需要更改。(1)我可以分别为每个表创建SQLiteOpenHelper,然后我可以在这些类上保留onCreate和onUpgrade,并且当实例化时,onUpgrade会为我的每个类运行吗?(2) 或者我应该在我的整个应用程序中只创建一个SQLiteOpenHelper类,并在同一位置包含所有创建表和所有更新?(3) 如何将SQLite数据库从emulator传输到PC?(4) 我是否需要加密数据库,或者Android存储在安全的地方?(1)不会工作,但(2)应该。请打开(3)和(4)的新问题,或者,更好的是,搜索答案,因为我确信这些问题已经涵盖。