为什么需要 database migration tool ?

2013-04-06 01:16:16 +08:00
 levon
alembic: https://pypi.python.org/pypi/alembic

我弄不懂为什么需要这东西,直接在mysql添加修改字段,表等,不是很方便吗?用这库还需要写代码去执行。
3525 次点击
所在节点    Python
8 条回复
Livid
2013-04-06 01:19:02 +08:00
假设 PB3 是一个开源软件,客户安装了 1.0 版本,然后在升级到 1.1 时,数据库结构发生改变了,这个时候就绝对需要迁移工具。
levon
2013-04-06 01:25:48 +08:00
恩,这应该是个实用场景。但是sql也可以搞定,发布一个update.sql,不是更简洁明了吗
Livid
2013-04-06 01:27:28 +08:00
@levon 如果是 1.0 -> 1.1 这种简单升级,那么确实可以只用一个差异 sql 搞定。

但是,如果是 1.1.5 -> 1.4.7 这种复杂升级……
levon
2013-04-06 01:33:29 +08:00
好吧,我没在实际中使用过,

意思是这工具在做数据库结构更新比直接写sql还简单,特别是很多修改的情况下。
chuangbo
2013-04-06 14:14:28 +08:00
@levon 在以下情况极其必要:多人协作、多分支、部署与数据库回滚。
因为数据库和代码不一样,不是打 diff 也不能简单的文件替换,没有版本,无法用 Git 或运维工具管理。有了 Migration Tools,数据库就有了版本,就可以像代码一样管理了,可以随意切换合并回滚版本,更灵活更方便。
duhastmich
2013-04-06 17:10:45 +08:00
sql 也可以吧,不过要往前滚,往后滚,逐步滚,得有个脚本来管理大量的sql 文件吧(02-up.sql, 02-down.sql, 03-up.sql...(这样的编号还有冲突的可能...)),还有数据库连接配置, 记录当前滚到哪个版本等
whtsky
2013-04-06 17:19:48 +08:00
@Livid 「假设 PB3 是一个开源软件」
是不是意味着 PB3 不打算开源了?
holsety
2013-04-06 17:54:51 +08:00
请问有对应mysql的类似工具吗?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/65049

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX