- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
情况
我正在开发一个使用 SQL Server 来存储数千条记录的 Web 应用程序。我们目前正在使用源代码控制软件来保存应用程序的每个版本。该应用程序有 2 个主要版本:
我们每个月左右发布一个新的“主要”Live 版本,但在此期间我们可能会发现当前 Live 版本上的许多小错误。为了修复这些错误,我们回到 Live 当前在我们的测试机器上运行的版本(我们使用共享数据库进行测试……)。重现错误,找到原因,修复它,然后我将补丁应用到有错误的版本,然后我们立即上线,并将错误修复合并到测试版本中。在每个“主要”版本之间的月份,我们可以发布很多小错误修复补丁。
问题
目前的问题是只有源代码在版本控制之下;数据库不受版本控制。这是一个问题的原因是,在开发下一个“主要”版本时,数据库中的许多内容可能会发生变化,与以前的版本不兼容。因此,即使我们可以回到以前版本的代码,数据库也不能做同样的事情,因此我们无法测试以前的版本,除非我们有当时的数据库备份。
显而易见的解决方案似乎是将数据库置于版本控制之下。虽然将数据库架构和静态数据置于版本控制之下并不是真正的问题(我想我会使用 Visual Studio Database Project ),但我很难了解如何处理用户输入的数据。
问题
我需要将用户输入的数据输入到我的表中才能测试应用程序,因此我该如何处理用户输入的数据?
最佳答案
根据我的经验,我建议结合使用数据库备份和数据库升级脚本。您应该为主要版本保留生产数据或类似生产数据的备份(根据契约(Contract),您可能有义务清除或更改包含客户姓名、地址、银行帐号等的数据)。从那开始,您应该能够获得数据库的任何中间版本,因为您正在编写数据库升级脚本并将它们保存在源代码控制系统中(您目前正在这样做,对吗?)
出于实际原因,您应该至少拥有两个独立的 QA 环境:一个具有与您的生产环境相匹配的数据库架构和应用程序,另一个 - 与正在开发的版本相匹配。
虽然数据库备份很大,但您只需要保留几个最新的备份,除非您预计需要对已停用多年的版本进行一些事后错误分析。
关于sql - 数据库版本控制——如何回到以前的版本并保留数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22866327/
我最后一次使用C++是在它无法被管理之前。不过最近,我从 Java 回来,看到现在可以管理 C++ 了! 没过多久我就意识到gcnew 和^ 的用途。但是,我对容器有点卡住了。 如何创建一个容器,其元
我离开 Microsoft 堆栈已有一段时间了,专注于 Linux、开源内容和 PHP 中的 Web 开发。我曾经在 Dev Studio(所有 C 和 C++)中在 Windows 上进行一些桌面应
在我的程序中有两个 View Controller 。第一个有表格 View 。当我单击一个单元格时,相关的炎症会显示在第二个 View Controller 中。它运作良好。 当我返回到第一个 Vi
我使用 AVAssetWriter 和 CMSampleBuffer 数据(来自视频、音频输入)录制视频(.mp4 文件)。 在录制时我想处理帧,我正在将 CMSampleBuffer 转换为 CII
在 python 中有两种不同的离开循环的选项。 continue 将您带回到循环的开头,break 就像一个电灯开关,它会在脚本运行的剩余时间内切断循环。我的问题是我有一个 while True 循
我是 Git 的新手,我正试图恢复到 SourceTree 中的先前提交。我右键单击要还原到的提交,然后单击 checkout 。它给了我一个提示,说我的工作副本将成为一个独立的头。这是什么意思,这是
所以我决定在离开几年后,为了我的一些个人项目重新使用 Ruby on Rails。我想知道的是,找出 Rails 中的新功能的最佳资源是什么?自从 1.2 是新的以来,我什至没有真正接触过 Rails
我的项目有两个部分。第一部分是在 Storyboard中制作的,第二部分是 SKView。如何从 SKView 中的第二部分返回到主 UIView? 最佳答案 创建自定义 ViewController
所以我在大约四次提交前对我的项目做了一个糟糕的改变。我了解到我可以恢复到之前描述的状态 here ,并通过依次检查以前的提交(并在我的设备上测试它们),我已经确定了问题发生的位置。 现在我想回到坏改变
我想知道,在 Canvas 的 commandAction 方法中,如何让我的命令按钮回到 MIDlet 的开始? (基本上重新开始)。 当按键触发时,我将它带到一个新的列表页面。在该页面上,我有一个
我想知道是否可以使用 intro.js 返回到下一行。我尝试了\n 和其他类似的东西,但它们中的任何一个都有效并且不可能在文档中找到类似的东西。有谁知道这是否可能? 最佳答案 正确的做法是像这样使用
这是关于我发现我的应用程序面临的一个反复出现的问题,它与使用几个 DialogFragment 相关。我主要针对平台级别 8 设备,因此要使用 DialogFragments,我必须使用兼容性库。 每
我有一个 uiview 的问题,它放置在 Storyboard的一个位置,在应用程序启动后,我将 uiview 移动到第二个位置,并使用代码中的按钮进行动画处理。 int alpha = -212;
我有 Controller B,它使用委托(delegate)模式将数据发送回 Controller A,但由于某种原因我的 segue 没有触发。 是否有什么东西阻止我的 segue 被触发?我将如
我已经找到了处理除我需要的之外的所有内容的解决方案。这是场景 就像在 GMail 中一样 - 主要内容呈现在 iframe 中。单击主页上的链接会指向 iframe。这效果很好,而且无缝。此时,如果我
我有一个 RCP 程序,带有需要登录的启动屏幕。 我想制作一个注销按钮。通过单击此按钮,用户应该返回到初始屏幕,因此他必须重新登录.. 这可能吗? 提前致谢。 最佳答案 如果您使用org.eclips
我有一个数据框: df = pd.DataFrame({'Section': [1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 6],
是否可以将元素 $("p") 返回到应用 mouseenter() 方法之前的确切颜色?或者我是否需要知道 mouseenter() 之前的颜色,然后使用 mouseleave() 应用该颜色?我希望
在 Matlab R2016b 中,显示某些数据类型的变量会显示有关该类型的信息。当通过不带最终分号键入变量来显示变量时会发生这种情况(使用 disp 函数时不会发生这种情况)。 比较例如: Matl
是否可以告诉 RSpec::Mocks 为一组值 stub 一个方法,否则回退到原始方法?例如: File.stub(:exist?).with(/txt/).and_return(true) Fil
我是一名优秀的程序员,十分优秀!