大家是如何把开发环境与生产环境表结构合并的? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
edk24
V2EX    问与答

大家是如何把开发环境与生产环境表结构合并的?

  •  
  •   edk24 2020-01-11 11:13:45 +08:00 4575 次点击
    这是一个创建于 2101 天前的主题,其中的信息可能已经有所发展或是发生改变。

    偶尔会遇到一些二开项目, 需要单独导出一份数据库, 用来二开.

    开发完成后, 可能追加了表, 追加 /修改了字段. 大家是怎么把表结构同步到生产环境的呢?

    目前我们的做法是, 把变更的字段记录下来. 等部署上线时逐一去修改.

    有没有更好的办法 /工具?

    16 条回复    2020-01-12 13:34:08 +08:00
    mgcnrx11
        1
    mgcnrx11  
       2020-01-11 11:19:00 +08:00 via iPhone
    liquibase ?
    murmur
        2
    murmur  
       2020-01-11 11:20:42 +08:00
    测试环境建表的时候就得准备 sql 语句,然后在仿真环境跑一遍,测试通过才能执行到正式环境
    webgrin
        3
    webgrin  
       2020-01-11 11:29:35 +08:00
    @mgcnrx11 有没有更简单的方法,不依赖特定工具的。同样有数据库合表的这个需求。
    liuzhaowei55
        4
    liuzhaowei55  
       2020-01-11 11:34:25 +08:00 via Android
    flyway
    webgrin
        5
    webgrin  
       2020-01-11 11:36:22 +08:00   1
    刚刚看来,Navicat 自带有这个表结构同步工具。商业版也不贵。
    felixin
        6
    felixin  
       2020-01-11 11:39:58 +08:00 via Android
    换用 mongodb ?
    295464512
        7
    295464512  
       2020-01-11 11:42:13 +08:00
    Navicat 结构同步妥妥的
    charlie21
        8
    charlie21  
       2020-01-11 12:11:46 +08:00 via Android
    sql 语句直接操作阿
    jugelizi
        9
    jugelizi  
       2020-01-11 12:22:24 +08:00

    你们不先灰度吗
    开发直接到生产
    JJstyle
        10
    JJstyle  
       2020-01-11 13:12:58 +08:00 via iPhone
    我们是会把每一期的数据库更新写到部署文档去的,领导按照部署文档操作即可。
    schemacs
        11
    schemacs  
       2020-01-11 13:35:29 +08:00   2
    如果是 mysql 的话 `mysqldbcompare --difftype=sql --run-all-tests --skip-row-count --skip-object-compare --changes-for=server2 [email protected]:3306 [email protected]:3308 db_online:db_offline`
    wwcxjun
        12
    wwcxjun  
       2020-01-11 14:01:01 +08:00
    用数据迁移吧(migrate).
    Felldeadbird
        13
    Felldeadbird  
       2020-01-11 15:15:31 +08:00
    我是将每次 更新的 SQL 记录在一个 版本号的 sql。传上线时执行。这样就可以确保不会遗忘了。
    tagtag
        14
    tagtag  
       2020-01-11 16:15:24 +08:00
    一直想用数据库的版本管理工具比如 flyway,但是大家都嫌麻烦。
    Ravenddd
        15
    Ravenddd  
       2020-01-11 17:18:47 +08:00 via Android
    navicat,数据库结构同步,数据同步很好用
    efaun
        16
    efaun  
       2020-01-12 13:34:08 +08:00
    navicat +1
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     3581 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 00:08 PVG 08:08 LAX 17:08 JFK 20:08
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86