使用VS2010的Database 项目模板统一管理数据库对象-阿里云开发者社区

开发者社区> 余二五> 正文

使用VS2010的Database 项目模板统一管理数据库对象

简介:
+关注继续查看

Visual Studio 2010 有一个数据库项目模板:Visual Studio Database Project(以下简称VSDP),VS 2003/2005/2008也有类似的项目,在VS2010上的得到了很大的加强,现在还具备了智能感知,构建时验证和自动部署功能,VSDP是针对典型的数据库开发任务而设计的,可以对原有数据库反向工程,添加表,存储过程和其他数据库项目,而且有选择性地将修改部署到目标数据库中。他的主要特性有:

1、模型对比(Schema Compare)

在项目的维护和升级期间,至少需要维护产品数据库(正在正式运营的数据库)、测试数据库、开发数据库这三个数据库,那开发数据库结构变更后,如何同步到其他两个数据库上呢?模型对比功能可以很好地解决此问题。如果开发数据库结构变更,可以通过选择菜单的Data → Schema Compare → Filter中选择Different Objects, Missing Objects or New Objects来过滤列表。这个过滤可以使我们快速地看到哪些修改需要更新到目标数据库中。然后我们可以保存修改脚本到一个文件中,并在T-SQL编辑器或者直接将修改精写入到目标数据库。

2、数据对比(Data Compare)

用来比较两个数据库的表或者视图中数据是否相同,可进行比较的前提是数据库名称一致、表具有相同的主键、唯一索引或唯一约束。比较完后可以对修改保存到目标数据库或者脚本。这个特性可以将产品数据库的数据导入到开发数据库或者测试数据库,以便于开发和测试。

3、数据生成计划(Data Generation Plans)

在项目中,开发团队每周至少一次提交版本到测试环境,测试人员针对新的数据结构如何快速生成测试基础数据呢? 数据生成计划会解决此问题。在数据生成计划计划中,我们要定义生成数据的表、每一个表要生成的记录行数和要插入数据的类型。数字类型比较容易生成,针对特殊的数据比如Email、电话号码可以通过正则表达式RegEx完成。

4、重构(Refactor)

主要用来重命名数据库对象,比如数据库名称,表名称,视图名称。当要重命名的对象改变后,对此对象的引用都会相应地改变。

下面我们来看看这个项目模板的基本使用方法:

在你的解决方案中添加项目,选择Database下的数据库模板,选择SQL Server 2008 Database Project,输入一个项目的名称,你也可以选择一个SQL Server 2005 Database Project。

image

点击OK按钮后就在我们的解决方案里头里加入了数据库的工程:

image

现在可以通过我们数据库工程进行相关的数据库开发工作了,例如通过Tables节点管理数据库表的对象:

image

添加一个数据库表,例如我们现在要创建的一个表叫做Applications,右键选中Tables节点,选择添加一个Table

image

输入表的名称,点击Add按钮,一个数据库表的脚本就创建好了,通过修改表的脚本进行数据库表的开发,目前只能使用T-SQL,没有可视化的界面:

image

下面我们需要给这个表添加个主键,右键Tables节点下的Keys节点,选择添加一个Primiary Key

image

输入Key的名称,点击Add按钮,一个数据库表的主键的脚本就创建好了

image

现在我们要把创建好的表部署到我们的开发数据库:

通过Build我们的数据库项目,VS2010会验证我们的数据库脚本并把database schema写到.dbschema扩展名的文件里:

image

部署脚本到数据库,右击项目,选择菜单项Deploy,VS会生成部署脚本:

image

然后就可以在你的开发数据库上运行部署脚本。但是如果你要确保你的开发数据库始终和你的开发过程同步,你可以设置你的数据库项目的属性,使得您的数据库的任何变化都会自动部署到开发数据库,双击数据库项目的属性,选择Deploy选项:

image

选择Deploy action,选择Create a deployment script (.sql) and deploy to the database,”。然后使用Edit按钮的目标连接设置连接到你的开发数据库。这时运行Deploy,就会把数据库脚本部署到你的开发数据库里了。

相关文章:






本文转自 张善友 51CTO博客,原文链接:http://blog.51cto.com/shanyou/312832,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
解决提交项目到GitHub,报错Please tell me who you are的问题
描述:         在第一次提交项目到GitHub时,出现了以下问题                  看了一下错误原因:Run git config --global user.email "you@example.
1609 0
oracl使用DataBase Configuration Assistant创建、删除数据库
原文:oracl使用DataBase Configuration Assistant创建、删除数据库可以使用DataBase Configuration Assistant来创建一个心得数据库。Database Configuration Assistant简称是DBCA,是创建、配置以及管理数据库的一个工具。
1269 0
【转】模板化的单例模式
from:http://www.haogongju.net/art/1535572  作者:mr_nop | 出处:博客园 | 2012/7/10 11:44:40   最近看的android代码,看到一个模板实现的单例模式,相当易用。
655 0
VS2010无法保存项目文件(.csprj)的问题解决方法
VS2010无法保存项目文件(.csprj)的问题解决方法   【出错提示】保存项目文件“XXX”时出错。类没有注册。正在查找具有CLSID的对象:{D9B3211D-E57F-4426-AAEF-30A806ADD397}。
968 0
c++ 使用vs2010调用 win32api
以前读书时都是用vc6.0.后来学c#用vs。装系统只装了vs2010.今天用vs2010写c++程序。发现有点陌生。就总结下,免得以后忘记。   首先用vs2010选择c++语言。新建一个win32控制台程序。
848 0
C#使用vs2010封装DLL
        使用C#生成DLL的方法是建立一个ClassLibrary工程。如我建立一个CL的工程名称是MyClassLibrary。我想把自己平时封装好的类放到该工程下,生成DLL,方便以后程序的调用。         可以通过简单的复制把写好的类复制到该工程下。         注意需要设置这类为public不然默认的是private.这样的话,即使以后引用了DLL,
851 0
使用ADO对象添加、修改、删除数据
使用ADO对象对数据库中的数据进行添加、修改和删除等操作。首先创建一个ADO类,通过ADO类连接数据库,并打开记录集。例如,使用ADO对象添加、修改、删除数据,程序设计步骤如下:(1)创建一个基于对话框的应用程序,将对话框的Caption属性修改“使用ADO对象添加、修改、删除数据”。
803 0
使用IntelliJ IDEA 14和Maven创建java web项目
原文:使用IntelliJ IDEA 14和Maven创建java web项目 http://mark.leanote.com/post/%E4%BD%BF%E7%94%A8IntelliJ-IDEA-14%E5%92%8CMaven%E5%88%9B%E5%BB%BAjava-web%E9%A1%B9%E7%9B%AE 安装Maven 下载安装 去maven官网下载最新版。
1283 0
生成项目目录结构(based on windows system)
描述:         作为程序员,在工作中,我们经常会有需求,需要罗列出项目的结构图;如果手工来整理的话,太过浪费时间,其实我们可以借助tree命令来快速生成目录结构。         本文主要介绍一下,基于windows系统,如何快速生成目录结构的方法。
2051 0
+关注
20382
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载