使用 DVCS [Mercurial] 将我的数据库置于版本控制之下

发布于 09-11 18:42 字数 186 浏览 10 评论 0原文

对整个数据库进行版本控制的最佳方法是什么?

为每个数据库对象(表、视图、过程……)创建一个文件,或者为所有 DDL 脚本创建一个文件,并且任何新的更改都将放在一个单独的文件中?

如何处理数据库管理器工具中所做的更改?

我希望有一个适用于任何类型的 RDBMS 的通用解决方案。

还有其他选择吗?

What would be the best approach for versioning my whole database ?

Creating a file for each database object (table,view,procedsure..) or rather having one file for all DDL scripts and any new change will be put in a separate file ?

What about handling changes made in a Database manager tool ?

I'd like to have a generic solutions for any kind of RDBMS.

Are there any other options ?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

我要还你自由2024-09-18 18:42:24

总的来说,我是 VCS 的忠实粉丝,也是 Mercurial 的大力支持者,但我真的认为您走错了路。

VCS 不仅仅涉及迭代变更、“什么”,还涉及回答“谁”、“何时”和“为什么”。对于数据库来说,这些答案不太有趣或者很难提供给 VCS。如果您每晚进行导出并提交,“谁”将始终是“cron”,“为什么”将始终是“午夜”。

现代 VCS 做得很好的另一件事是帮助您合并来自多个分支的更改。这在数据库领域不太适用。你很少会说“我想要这个表结构,但是这个数据”,如果你这样做,文本/差异合并不会对你有太大帮助。

能够很好地完成“什么”和“何时”的事情是增量备份系统,这可能是更合适的选择。

在工作中我们使用 Tivoli,在家里我使用 rdiff-backup 和 duplicity,但是还有很多不错的选择。

我想我的一般经验法则是“如果它是由人手工输入的,那么它就会进入源代码管理,如果它是生成/导出的,那么它就会进入增量备份”

当然你可以完成这项工作,但我不这样做与更传统的备份解决方案相比,它不会给您带来太多好处。

I'm a huge VCS fan in general and a big Mercurial booster, but I really think you're going down the wrong path.

VCSs aren't just about iterative changes, the "what", they're also about answering the "who", "when", and "why". For a database those answers are a lot less interesting or hard to provide to the VCS. If you're doing nightly exports and commits the "who" will always be "cron" and the "why" will always be "midnight".

The other thing modern VCSs do really well is helping you merge changes from multiple branches. That's less applicable in the database world. Very seldom do you say "I want this table structure, but this data", and if you do the text/diff merge isn't going to help you much.

The thing that does do "what" and "when" very well is an incremental backup system, and that's probably the better fit.

At work we use Tivoli and at home I use rdiff-backup and duplicity, but there are plenty of great options.

I guess my general rule of thumb is "if it was typed by hand by a human then it does into source control, and if it was generated/exported then it goes in the incremental backups"

Certainly you can make this work, but I don't think it will buy you much over the more traditional backup solutions.

过期以后2024-09-18 18:42:24

看看这篇帖子

Have a look at this post

咆哮2024-09-18 18:42:24

如果您需要通用解决方案 - 将所有内容放入脚本(简单文本文件)中并置于版本控制系统下(可以使用任何 VCS)。

将类似的数据库对象分组到脚本中将取决于您的要求。

因此,您可以例如:

将表/索引/存储在一个或多个脚本中
每个过程存储在单独的脚本中或将小过程组合成一个脚本。

但是,使用这种方法需要记住一件重要的事情:如果直接在数据库中更改表/视图/过程,请不要忘记更改脚本,并且在更改脚本后不要在数据库中创建/重新创建/编译数据库对象。

If you need generic solution - put everything in the scripts (simple text files) and put under Version Control system (can be used any of VCS).

Grouping similar database objects into scripts will be depend on your requirement.

So you may for example:

Store table/indexes/ in one or several script
Each procedure store in individual script or combine small procedures into one script.

However need to remember one important thing with this approach: don't forget change scripts if you changed table/view/procedure directly in databases and don't create/recreate/compile you db objects in database after changing scripts.

月下客2024-09-18 18:42:24

SQL Source Control 目前支持 SVN 和 TFS,但 Mercurial 请求正在迅速增加,我们'我们希望很快就能有一个关于这个的故事。

我们使用 UserVoice 来衡量需求,因此如果您对此感兴趣,请相应投票:http ://redgate.uservoice.com/forums/39019-sql-source-control

SQL Source Control currently supports SVN and TFS, but Mercurial requests are increasing rapidly and we're hoping to have a story for this very soon.

We use UserVoice to measure demand so please vote accordingly if you're interesting in this: http://redgate.uservoice.com/forums/39019-sql-source-control

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文