V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
levon
V2EX  ›  Python

为什么需要 database migration tool ?

  •  
  •   levon · 2013-04-06 01:16:16 +08:00 · 3496 次点击
    这是一个创建于 4046 天前的主题,其中的信息可能已经有所发展或是发生改变。
    alembic: https://pypi.python.org/pypi/alembic

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

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

    意思是这工具在做数据库结构更新比直接写sql还简单,特别是很多修改的情况下。
    chuangbo
        5
    chuangbo  
       2013-04-06 14:14:28 +08:00   ❤️ 1
    @levon 在以下情况极其必要:多人协作、多分支、部署与数据库回滚。
    因为数据库和代码不一样,不是打 diff 也不能简单的文件替换,没有版本,无法用 Git 或运维工具管理。有了 Migration Tools,数据库就有了版本,就可以像代码一样管理了,可以随意切换合并回滚版本,更灵活更方便。
    duhastmich
        6
    duhastmich  
       2013-04-06 17:10:45 +08:00
    sql 也可以吧,不过要往前滚,往后滚,逐步滚,得有个脚本来管理大量的sql 文件吧(02-up.sql, 02-down.sql, 03-up.sql...(这样的编号还有冲突的可能...)),还有数据库连接配置, 记录当前滚到哪个版本等
    whtsky
        7
    whtsky  
       2013-04-06 17:19:48 +08:00 via iPhone
    @Livid 「假设 PB3 是一个开源软件」
    是不是意味着 PB3 不打算开源了?
    holsety
        8
    holsety  
       2013-04-06 17:54:51 +08:00
    请问有对应mysql的类似工具吗?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2383 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 11:40 · PVG 19:40 · LAX 04:40 · JFK 07:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.