InfoQ

新闻

Visual Studio 2008中的SQL数据库发布

作者 Hartmut Wilms译者 郭晓刚 发布于 2007年10月23日 上午10时4分

社区
.NET
主题
部署/数据中心
标签
Visual Studio,
数据库,
MSBuild,
持续集成

数据库发布向导(Database Publishing Wizard)是一个流行的Visual Studio插件,它支持把本地的数据库部署到远程主机上去。Visual Web Developer团队宣布将把这个向导集成到Visual Studio 2008之中

目前Visual Studio 2008的Beta 2版本还没包含这个向导,不过预计2008年2月发布的VS 2008 RTM将会一并安装这个向导的1.2版。这个数据库发布插件现在的版本是1.1,从属于SQL Server Hosting Toolkit。这个工具包为主机服务的用户和提供者提供了以下方案:

  • 对于主机服务的客户
    • Database Publishing Wizard简化了上载数据库到主机的操作,还可以根据对象或者你的数据库中的数据生成T-SQL。
  • 对于主机服务提供者
    • Database Publishing Services是一组ASP.NET Web Services,你可以很容易地部署它,从而方便你的客户在你的环境中部署SQL Server数据库。

Scott Guthrie为Visual Studio Database Publishing插件的首个发布版本写了一篇部署数据库的详细指南,还写了一篇对目前1.1版的概要介绍

虽然这个发布向导在SQL Server数据库的部署方面是一个不错的开始,但它要成为一个完全成熟的构建方案还缺乏不少特性。Jean-Paul Boodhoo在博客上撰写了一系列文章,讨论“用NAnt自动化构建”。其中第6部分讨论了构建SQL Server数据库的设置和定制细节。

Peter Hancock也写了一篇文章介绍他将数据库部署融入持续集成的经验:

这篇文章是阅读Martin Fowler和Pramod Sadalage写的《Evolutionary Database Design》之后受到的启发。概念很好,但我在网上找不到如何实现的具体说明。于是我决定自己从头开始。
[...]
成功运行并不困难,而努力的回报是巨大的。在我以前的公司里,脚本的运行是由DBA完成的,其间还要花一周时间召集所有人一起确保脚本能正常工作,回滚失败的脚本,更新依赖于失败脚本的脚本诸如此类。抄写错误、权限错误、脚本错误、前后不一致等等都很常出现。通过像单元测试一样频繁对部署进行测试,我们就能减少错误的倾向。最后还要提醒,数据库的修改变得更方便,并不意味着程序员可以随便改数据表。数据库的设计还是需要深思熟虑的。

在构建中集成数据库部署,还可以选用VS里的“数据库项目”以及相应的MSBuild task。MSDN上提供了一篇《数据库构建及部署概述》,适用于VS 2005和VS 2008

查看英文原文:SQL Database Publishing in Visual Studio 2008 and Today

相关赞助商

InfoQ中文站.NET社区,关注.NET和微软的其他企业开发解决方案,通过新闻、文章、视频访谈和演讲以及迷你书等为中国.NET社区提供一流资讯。

没有回复

回复

独家内容

虚拟化导论

人们很容易想当然的以为虚拟化技术仅仅应用于服务器。而在现实中,虚拟化这一苏醒的概念正被运用于各个层面,其中包括网络,存储以及应用基础架构。在这篇导论中,InfoQ将深入每个方面,详尽向您描述虚拟化技术的运用以及其优点与不足。

用户故事估算技巧

作为开发者,同时也是ThoughtWorks的咨询师,Jay Fields总结了自己估算用户故事的有效技巧。

InfoQ案例研究:纳斯达克市场回放

在这篇案例研究中,InfoQ对Adobe AIR和Amazon的简单存储服务(Simple Storage Service ,S3)在NASDAQ市场回放程序(NASDAQ Market Replay)中的应用进行了详细的分析。

Hadoop基本流程与应用开发

本文介绍了Hadoop的基本流程、业务场景、代码范例以及集成测试。本文是《分布式计算开源框架Hadoop入门实践》三部曲的最后一部。

SOA在互联网系统中的应用

本视频对SOA在互联网系统中的应用进行了探讨,主要以支付宝在SOA的实践为例,主题从敏捷的应用程序(对象与组件)到敏捷的企业系统(应用集成与面向服务),再到敏捷的生态圈(网关与开放平台)。

用数字沟通——来自敏捷精灵的忠告

因为不知道如何反击,技术人员不得不听从业务人员的要求。这已经是老生常谈了。问题何在?开发人员用数字主要是进行计算的,而业务人员使用数字辅助决策。在下面的故事中,“敏捷精灵”鼓励一个开发人员用数字来描述与计算无关的问题。

Hadoop中的集群配置和使用技巧

本文介绍了Hadoop如何配置分布式框架运行环境,同时特别讲解了其中的一些细节。Hadoop可以单机跑,也可以配置集群跑,这里主要重点说一下集群配置运行的过程。本文是Hadoop入门实践三部曲的第二部。

JavaScript多线程编程简介

虽然有越来越多的网站在采用AJAX技术,但是开发复杂的AJAX应用仍然是个难题。本文探索了如何应用多线程缓解其中一些问题。