一起谈.NET技术,使用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。

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

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

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

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

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

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

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

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

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

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

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

时间: 2024-09-14 15:15:07

一起谈.NET技术,使用VS2010的Database项目模板统一管理数据库对象的相关文章

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

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

使用VS2010的Database项目模板统一管理数“.NET研究”据库对象

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

一起谈.NET技术,VS2010 测试功能之旅:编码的UI测试(4)-通过编写测试代码的方式建立UI测试(下)

回顾 最近比较忙,距离上次更新的时间较久,见谅. 在本章上部分,介绍了"添加用户"窗口的测试代码编写.想必大家也看到了,在UIMap.cs文件中实现自定义编码是一件很轻松的事情,接下来将介绍下个部分,查询用户窗体的测试代码的编写,以及他们测试的关联. 示例程序介绍 系统主窗口:(下载点我) 该系统拥有两个功能,"添加用户"和"查询用户": 点击添加用户后,进入添加用户子窗体:("添加用户"窗口的测试代码编写在上部分已经实现)

一起谈.NET技术,VS2010测试功能之旅:编码的UI测试(3)-操作对象的识别原理

回顾  在之前的两章分别介绍了一个简单的示例, 操作动作的录制原理,通过修改UIMap.UItest文件控制操作动作代码的生成.想必大家对编码的UI测试操作动作的录制应该有一定了解了,在UI操作中,操作动作总是离不开具体的操作对象,例如点击,拖动,填写值等操作,总是要对文本框,或者按钮,窗体这些对象进行操作,不是凭空生成的.本章作为入门篇的最后一章,将会说明编码的UI测试是如何识别这些对象的,并介绍UIMap.UItest文件是如何生成对象识别代码. 对象的识别原理 之前我们录制的时候,录制生成

一起谈.NET技术,VS2010实践RUP4+1架构模型

RUP4+1架构方法 RUP4+1架构方法采用用例驱动,在软件生命周期的各个阶段对软件进行建模,从不同视角对系统进行解读,从而形成统一软件过程架构描述.                   图 1. RUP4+1架构图 用例视图(Use Cases View),最初称为场景视图,关注最终用户需求,为整个技术架构的上线文环境.通常用UML用例图和活动图描述. 逻辑视图(Logical view),主要整个系统的抽象结构表述主要关注系统提供最终用户的功能,不涉及具体的编译即输出和部署,通常在UML中

一起谈.NET技术,VS2010如何做WAP开发

自从VS2010 RC出来以后,就顺便把机器重做了,重装的时候特意没安装VS2008,全线过渡到VS2010和.net4.0,但今天有一小WAP项目,才意识到VS2010貌似不支持WAP窗体,按照记忆参考以前VS2008的做法(见:wap开发体会),下载模板后,一时眼花即没找到新建Mobile Web窗体的地方,于是又把VS2008装回来了,等到把VS2008搞定后,怀着一颗不死之心又重新到VS2010里瞅了瞅,发现其实也可以的(哎,真想抽自己),见下图: 项目上右击-->Add-->New

一起谈.NET技术,VS2010&.Net 4.0 之并行运算(Parallel)(For、Foreach)

VS2010&.Net 4.0的Beta2相比Beta1在性能上有了很大的改进,已经基本可以使用了..NET 4.0给我们带来许多新特性,如动态类型.云平台.并行运算等.本文讨论一下.NET 4.0的并行运算. 其实并行运算并不是在.Net 4.0才有的.大家都知道,通过增加CPU的主频可以提高CPU的性能,但由于设计的限制,主频是不可能无限制的提高.这个时候,把提高性能的方式转向使用多个心(多核),现在的电脑几乎都是多核的.但在软件中并还没有跟上这个节奏,大多数软件还是采用传统的方式,并没有很

一起谈.NET技术,VS2010测试功能之旅:编码的UI测试(1)

前言 研究VS2010的自动化测试有一段时间了,在研究的过程中,发现网上的VS2010相关的测试资料十分稀少,这给学习带来比较大的困难.幸运的是,自己因为常用QuickTest Professional做自动化测试,并且对.Net代码比较了解,使得在学习的过程中并不是特别困难,对UI CODED TEST也已经有一定了解.本着与大家交流,共同进步的想法,思考之后,决定写这些随笔,来对VS2010的测试功能做一些探索和总结.希望大家能够多多指教! 自动化测试  自动化测试指软件测试的自动化,软件测

一起谈.NET技术,VS2010测试功能之旅:编码的UI测试(2)-操作动作的录制原理(上)

回顾  在之前我们介绍了如何用VS2010的UI测试功能创建一个简单的示例,大致描述了如何使用编码的UI测试进行录制和回放,在这章会着重描述VS2010是如何录制操作,并且生成代码,以及初步介绍如何通过自己写代码的方式进行测试. 内容简介  在上一章我们已经介绍过,建立一个编码的UI测试CodedUITest1.cs,录制完成之后,会自动生成一个UIMap1.uitest文件.  图1:录制完成后自动生成的UIMap1.uitest文件  事实上,在录制过程中起着关键作用的并非是CodedUIT