对于一个软件企业来说,源代码就是公司全体智慧的结晶,绝不能有任何闪失。但对于公司产品的基石数据库怎么来 进行统一管理呢?通常,是直接备份数据库文件的方式,或者生成数据库的部署脚本,来重复的备份。这个方法可行, 却有些值得改进的地方。首先,太繁琐了,浪费精神;其二,不方便和其它项目同时管理。下面,就介绍我偶然看到的 方法,当然,可能有很多人已经这么做了,但分享给那些还不知道的人。
大体思路:
VS 2010 提供了一个项目类型,新建->数据库->SQL Server 2005 数据库对象 或 SQL Server 2008 数据库对 象,完整的提供了SQL Server 的定义创建和生成部署脚本功能。
通过VS 2010下的数据->架构比较(Schema Compare)能将SQL Server数据库和SQLServer数据库项目差异比较出 来,并提供双向同步功能。
Subversion,提供基于文本的SQL语句版本管理支持。
本示例采用VisualSVN-Server(Subversion 服务器)、AnkhSvn(VS 2010的Svn 插件)、SQL Server2005、VS 2010 ,示例数据库为AdventureWorks。
因为安装的是英文版的VS2010,大家就对应着中文的看吧。
第一步:通过VS 2010 创建数据库项目。打开VS 2010,File->New->Project,在Recent Templates中 选中Database->SQL Server,并在右面的项目类型中选中SQL Server 2005 Database Project,输入项目名称,并点 击OK。
第二步:在新建的ExampleSystemSQL项目上点右键,选中菜单中的Import Database Objects and Settings,