本文转自:http://www.cnblogs.com/shanyou/archive/2010/05/08/1730810.html

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,就会把数据库脚本部署到你的开发数据库里了。

相关文章:

  • VS2010中创建自定义SQL Rule
  • Using an Existing Database
  • Adding Tables
  • Adding Stored Procedures
  • Building and Deployment

[转]使用VS2010的Database 项目模板统一管理数据库对象相关推荐

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

    Visual Studio 2010 有一个数据库项目模板:Visual Studio Database Project(以下简称VSDP),VS 2003/2005/2008也有类似的项目,在VS2 ...

  2. Abp项目模板使用Oracle数据库包括系统权限管理

    Abp项目模板使用Oracle数据库包括系统权限管理 by dacong 参考:Abp项目的创建以及Oracle的支持 aspnet-zero-core 使用MySql数据库 http://www.s ...

  3. abp如何连接oracle,Abp项目模板使用Oracle数据库

    [实例简介] Abp项目模板使用Oracle11g数据库包括系统权限管理,Abp.Zero [实例截图] [核心代码] 0df058ea-1862-4668-8b8e-11d4ab5618c3 ├── ...

  4. 如何在 ETL 项目中统一管理上百个 SSIS 包的日志和包配置框架

    一直准备写这么一篇有关 SSIS 日志系统的文章,但是发现很难一次写的很完整.因为这篇文章的内容可扩展的性太强,每多扩展一部分就意味着需要更多代码,示例和理论支撑.因此,我选择我觉得比较通用的 LOG ...

  5. 在vue项目中统一管理api

    在前后端分离的项目中,前端对api进行统一管理. 第一步:进行跨域配置: 在config下index.js中修改以下代码: 第二步:创建自己接口封装的文件 在src目录下创建HTTP文件夹.文件目录结 ...

  6. django ajax获取数据类型,Django:使用Ajax获取模板中的数据库对象值

    您可以使用AJAX回打电话给你的Django代码,并返回你的车的名称: template.html $(document).ready(function() { $(document).on(&quo ...

  7. Gradle7.0,依赖统一管理的全新方式,了解一下~

    作者 | RicardoMJiang 来源 | https://juejin.cn/post/6997396071055900680 我估计用到这么高版本的同学非常少,大家可以简单了解下,做个收藏,未 ...

  8. java版本号管理_微服务项目中如何管理依赖版本号?

    本文是微服务项目代码组织形式三部曲中的第三篇,也是最后一篇,通过这三篇文章,相信大家对于如果组织微服务中的代码已经有了一个基本认知,前面两篇分别是: 第三篇相对来说要简单一些,本来没打算写,但是上周有 ...

  9. 微服务项目中如何管理依赖版本号?

    本文是微服务项目代码组织形式三部曲中的第三篇,也是最后一篇,通过这三篇文章,相信大家对于如果组织微服务中的代码已经有了一个基本认知,前面两篇分别是: 微服务项目搭建,到底要不要聚合工程? 在微服务项目 ...

最新文章

  1. xp里删除不想要的删不掉的帐户
  2. 在LINUX终端和VIM下复制粘贴
  3. shell脚本将本地docker镜像push到阿里云镜像仓库
  4. 补充spring事务传播性没有考虑的几种情况
  5. ALV GRID中实现RadioButton单选按钮
  6. Hadoop基础--HDFS/Yarn/MapReduce概述
  7. 栈的典型应用 —— 逆序输出
  8. Linux bash shell递归函数
  9. 拓端tecdat|【视频】Lasso回归、岭回归等正则化回归数学原理及R语言实例
  10. 最全MySQL数据类型详解
  11. 约翰·库缇斯(没有双腿的激励大师,年轻人必看)转载
  12. 陈龙杰计算机专业,第四届学生职业技能大赛获奖名单
  13. 华南理工计算机就业棒棒,为梦想、为公益,华南理工大学学子为爱发声
  14. 恶意软件隐身术:把可执行文件隐藏在注册表里
  15. cocos-Lua FairyGUI 之 列表(九)
  16. 【031902238崔佳雪】
  17. 如何起Linux服务器的21端口,linux下开启ftp的21号端口
  18. Power BI产品帕累托分析
  19. 遗失的访谈——岁月无声
  20. 数术记遗——盘点我国古代那些失传了的计算神器

热门文章

  1. win7重装系统时,使用PE工具箱进入系统看到的“C盘变成0.2G,D盘变成48G左右”这是什么回事?...
  2. 有关Cassandra节点之间的通信:Gossip【译】
  3. ASP.net控件开发系列(四)
  4. php %3ch1%3e字体,phpWebSite搜索模块跨站脚本执行漏洞
  5. Mysql 面试常问5 让你根据业务写出比较复杂的SQL,往往和 Group BY 与 Having 相关
  6. git 常用操作,撤销修改
  7. 每个人都应该学git,最新GitHub上git指南我不信你不会git
  8. MySQL数据库常用的操作命令(二)
  9. 基于 TrueLicense 的项目证书验证
  10. 详谈java类和对象的生命周期