您如何在团队环境中维护有用的 SQL 库?

Posted

技术标签:

【中文标题】您如何在团队环境中维护有用的 SQL 库?【英文标题】:How do you maintain a library of useful SQL in a team environment? 【发布时间】:2008-10-15 14:52:37 【问题描述】:

在我的工作中,每个人都有用来回答问题的 sql sn-ps。有些是特定于客户的,而有些是针对给定数据库的通用的。我想将这些查询合并到一个库/存储库中,团队中的任何人都可以访问。要求是:

    无障碍 可搜索 可标记(每个 sql 允许多个标记) 可导出(创建一个包含所有带有特定标签的查询的文档)

我对在其他团队环境中发现的工作感兴趣。

【问题讨论】:

【参考方案1】:

你可以使用维基。

您可以从 Tiddly wiki 这样简单的东西开始。

【讨论】:

这是个好主意!我不相信我没有想到!我打算今天下午在我家开始。【参考方案2】:

wiki 是一种很好的方法。

对于特定于数据库或特定于项目的 sn-ps,链接到代码中出现类似结构的位置也非常有用。我们使用 trac 的 wiki,它提供了与 SVN 的良好集成。

【讨论】:

【参考方案3】:

比起粘贴 SQL sn-ps,我会考虑升级到 ORM(对象关系映射器)或其他一些库,以便更轻松地表示和操作数据。它提供了一层封装以防止模式更改和一层抽象,因此您可以根据业务逻辑(即用户)而不是表的集合(即用户表、密码表)来考虑数据,访问表...)。

在 Perl 中,这类似于 DBIx::Class。

【讨论】:

【参考方案4】:

您可能希望了解的另一种方法是在数据库中创建视图。 'select * from some_view' 可以隐藏相当多的 SQL。您仍然希望使用 wiki 来记录它们,但如果它是一个视图,您不必担心人们会保留过时的副本。

【讨论】:

以上是关于您如何在团队环境中维护有用的 SQL 库?的主要内容,如果未能解决你的问题,请参考以下文章

如何在基于 Docker 的微服务中管理每个环境的数据?

「非常有用」如何正确地给开源项目提交pr?

您如何在不同的暂存环境中维护 java webapps?

Gradle依赖管理:如何在android项目中维护新旧版本的依赖项?

OAuth2 的客户端 JS 库如何维护安全认证?

在 SQL Server 的维护计划中添加 T-SQL