前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >生产环境在对Web应用进行版本回退时针对数据库表的回滚操作

生产环境在对Web应用进行版本回退时针对数据库表的回滚操作

作者头像
翎野君
发布2023-05-12 20:25:10
2720
发布2023-05-12 20:25:10
举报
文章被收录于专栏:翎野君翎野君

背景

同组的一位负责B端Web项目的同事将版本发布到生产环境之后。收到了用户很多投诉,诸如功能很难用、操作流水很繁琐。产品经理进行分析检讨,判断是因为新旧版本系统用户使用习惯差异太大,且没有兼容原有功能。经过短暂的商议后决定回退版本。

因为是web应用所有直接将服务端的版本包回退到上次发版即可。但是在回退的时候需要考虑一个问题就是当初发版的时候可是提了一些DDL和DML的SQL脚本, 比如升级的时候增加了一些新的字段且设置为必填、增加了新的唯一索引等。

解答

当新版本灰度发布表现不佳时,应回滚至旧版本。对于纯粹的Web应用而言,回滚相对简单。主要难点在于用户数据的无缝切换。对于客户端应用,如果期待用户自行卸载新版本另行安装旧版本,成本和流失率都太高。可以考虑通过快速另行发布新版本,利用升级来“回滚”,覆盖上次灰度发布的修改。

那位同事需要准备的SQL事项如下

1.在原有表上新增的字段,如果是Not Null,则需要将字段改为Default Null。

2.在原有表上新增的唯一索引约束,需要将新增的唯一索引Drop掉。

3.新增一张表,不需要处理。

4.基于新版本代码生成的新的数据,需要进行删除。

5.基于新版本代码更新了原有的数据,需要具体业务具体分析,比如如新版本中在原有的类型字段如showType中新增了一种类型,以前只有A和B两种类型,现在扩充了C、D、E。那么回滚之后如果后续业务逻辑中会查出来这些数据,并进行判断等相关逻辑处理时,那么就有可能会报错,所以需要与需求方确认,判断是删除掉这部分数据,还是修复这部分数据。

建议

在进行版本迭代升级时,一般数据库不建议删除列,也不建议变更字段的含义,如果需要则优先考虑添加新字段,或者新建表通过外键关联起来,这样升级、回退,都不太会出现太大的问题。

首发链接:https://cloud.tencent.com/developer/article/2285725

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-01-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 背景
  • 解答
  • 建议
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档