使用alembic升级Sqlite3模式
Sqlite3 schema upgrade using alembic
我有一个c++应用程序(Linux),通过api使用sqlite3 db。目前,DB是随二进制文件一起在RPM中发布的。这个DB已经包含了所有需要的表。我的应用程序在运行时不会尝试更改任何模式。现在我必须支持下一个版本的数据库模式升级,因为模式可能会发生变化。知道我该怎么做吗?
Alembic绝对可以做你想做的事情,但考虑到你的应用程序是用c++而不是python编写的,用python维护所有表的声明性模型可能不值得付出努力。鉴于您只使用sqlite,我建议您手工编写SQL更新语句,然后从alembics书中取出一页,创建一个包含一个条目的版本表-当前数据库版本。
当你的应用程序启动时,检查当前的数据库版本,并按顺序运行迁移脚本,直到数据库迁移到最新版本。
PS:帮你自己一个忙,也写降级脚本。如果出于某种原因需要回滚
相关文章:
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 为什么在保护模式下继承升级不起作用
- 如何在全屏模式下(在OpenGL中)使背景透明
- 为什么使用__LINE_的代码在发布模式下在MSVC下编译,而不是在调试模式下
- 派生类是否可以在抽象工厂设计模式中具有数据成员
- 此模式的C++RegEx
- avrogencpp能为模式中的每种类型生成单独的头文件吗
- 使用可变模板的Broadcaster/Listener模式
- c++方法参数只能在linux的发布模式下自行更改
- 无法在windows上使用mingw将sqlite3与c连接
- 资源管理设计模式
- 使用 mod_gsoap 部署服务时,如何在 Gsoap 中更改 soap 上下文的模式?
- C++ 无法在字符数组中使用 for 循环打印字母模式
- 小字符串优化(调试与发布模式)
- sqlite3 和生成文件中的链接出现问题
- 可视化C++:发布模式的运行时库作为'Multi-threaded Debug DLL'
- 是否可以在 sqlite3 中READ_ONLY数据库切换到 WAL 日记模式
- 多线程模式下的SQLite3:执行到底不安全
- 使用alembic升级Sqlite3模式
- 如果我为多个编写器使用额外的互斥锁,我可以在 SQLite3 中使用 WAL 模式吗?