我的应用程序正在生产中,我想在用户更新应用程序时管理用户数据而不丢失他们的数据,我如何使用 sqflite
实现此目的。明确地我想添加一列并删除另一列。
最佳答案
你或许可以 add a column使用原始 sql,但 sqlite(因此 sqflite)不支持删除列。为此,您需要执行以下操作:
- 增加数据库版本号
- 在
onUpgrade
中将旧的数据库列复制到临时表 - 删除原表
- 使用原始表名但使用正确的架构创建一个新表
- 从临时表中复制数据
- 删除临时表
抱歉,这不是一个完整的答案,但如果我处于您的情况,这就是我会去的方向。
关于dart - Flutter - 如何更新 Sqflite 中的表结构?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54095892/