- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
你如何为 Visual Studio 项目管理你的 sql server 数据库构建/部署/迁移?
我们的产品包含合理的数据库部分(~100 个表,~500 个进程/函数/ View ),因此我们需要能够部署当前版本的新数据库以及将旧数据库升级到当前版本。目前,我们维护用于创建新数据库和版本之间迁移的单独脚本。显然不理想,但其他人如何处理这个问题?
这对我们来说很复杂,因为有许多客户都有自己的数据库实例,而不是说我们自己的 Web 服务器上只有开发/测试/实时实例,但是为其他人管理开发/测试/实时的过程必须是相似的。
更新:我不想使用任何像 RedGate 那样的专有产品(尽管我一直听说它们非常好,并且会考虑将其作为解决方案)。
最佳答案
我们使用 Red-Gate SQLCompare 和 SQLDataCompare 来处理这个问题。这个想法很简单。这两种比较产品都可以让您将选定表(例如配置表)中的模式或数据的完整图像作为脚本进行维护。然后,您可以将任何数据库与脚本进行比较并获得更改脚本。我们将脚本保存在我们的 Mercurial 源代码控制中,并标记(标签)每个版本。然后,支持人员可以获取任何版本的脚本,并使用 Redgate 工具从头开始创建或升级。
Redgate 还有一个 API 产品,允许您从代码中执行比较功能。例如,这将允许您在安装程序或产品本身中具有自动升级功能。我们经常将它用于我们托管的 Web 应用程序,因为它使我们能够更完全地自动化部署过程。在我们的例子中,我们有一个支持可以执行的 MSBuild 任务来执行自动推出和升级。如果您分发给第三方,则必须为每个包含 API 的分发支付少量的额外许可费。
Redgate 还有一个工具可以自动打包数据库安装或升级。我们不使用那个,因为我们发现与版本的脚本进行比较为我们提供了更大的灵活性。
Redgate 工具还可以帮助我们进行开发,因为它们使以非常细粒度的方式对架构和配置数据进行源控制变得微不足道(每个数据库对象都可以放在自己的文件中)
关于sql-server - 您如何管理用于新构建和迁移的 sqlserver 数据库项目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2675609/
在我的 Windows 类库(由 MVC 网站使用)中,我安装了 NugetPackage Microsoft.SqlServer.Types (Spatial)。 现在,我正在使用 ado.net
测试sql: 复制代码代码如下: SET STATISTICS IO ON SET STATISTICS TIME ON SELECT COUNT(1)&n
我正在从 SqlConnection 构建 DbContext。当我使用它时,我收到以下错误: The Entity Framework provider type 'System.Data.Enti
我使用dotNet 4.5创建了WCF服务。数据库层是使用Entity Framework 6构建的。 我使用IIS 8托管了该服务。它运行正常。 现在,我需要使用Windows窗体客户端使用该服务,
我正在尝试从 SqlServer 1 上的 sql 数据库中导出一些表。在我们的内部网 LAN(就在我旁边)中有一个我制作的临时 Sql Server,称为 SqlServer 2。 我不想备份整个数
Error 1 Copying file bin\EntityFramework.SqlServer.xml to obj\Debug\Package\PackageTmp\bin\Entit
我正在尝试使用 SMO 通过 Powershell 恢复数据库,但是当我尝试定义和使用服务器对象时,出现以下错误: Cannot convert argument "srv", with value:
出于某种原因,我需要将我的表列之一从“NOT NULL”更新为“NULL”。命令很简单: ALTER TABLE TBLOGDOCMESSAGE ALTER COLUMN PROCESSID BIGI
我想知道我正在尝试做的事情是否可行。我相信它是在 TSQL 中使用 PIVOT 函数,但对 PIVOT 函数没有足够的经验来知道从哪里开始。 基本上,我正在尝试采用以下名为 #tmpbudgetdat
我正在尝试将子查询作为带有条件的列。 我从 SQL Server 得到的错误是: 子查询返回了 1 个以上的值。当子查询跟随 =、!=、、>= 或当子查询用作表达式时,这是不允许的。 我正在选择更多的
我有一个正在查询的 SQL 服务器数据库,我只想在特定行为空时获取信息。我使用了一个 where 语句,例如: WHERE database.foobar = NULL 它不返回任何东西。但是,我知道
1、拼接字符串(整个字符串不分割)步骤: 首先在字符串的前后加单引号; 字符串中的变量以'''+@para+'''在字符串中表示; 若在执行时存在类型转换错误,则应用相应的类型
说明: 收缩日志的原因有很多种,有些是考虑空间不足,有些则是应用程序限制导致的。 ?
Rand()函数是系统自带的获取随机数的函数,可以直接运行select rand() 获取0~1之间的float型的数字。 如果想要获取0~100之间的整数随机数,可以这样使用 select ro
将以下内容保存为 openSql.bat 双击运行即可 复制代码 代码如下: @echo ========= SQL Server Ports =================== @ech
新增的APPLY表运算符把右表表达式应用到左表表达式中的每一行。它不像JOIN那样先计算那个表表达式都可以,APPLY必选先逻辑地计算左表达式。这种计算输入的逻辑顺序允许吧右表达式关联到左表表达式。
SQL Server本身提供了这么一个DMV来返回这些信息,它就是sys.dm_exec_sessions 。 比如在我的机器上做一下查询: 复制代码 代码如下: SELECT * FROM
尽管从技术上讲,其它排名函数的计算与ROW_NUMBER类似,但它们的的实际应用却少很多。RANK和DENSE——RANK主要用于排名和积分。NTILE更多地用于分析。 先创建一个示例表: 复制
1、文件和文件组的含义与关系 每个数据库有一个主数据文件.和若干个从文件。文件是数据库的物理体现。 文件组可以包括分布在多个逻辑分区的文件,实现负载平衡。文件组允许对文件进行分组,以便于管理和数据的
我想很多人都知道,在oracle里面,存储过程里面可以传入数组(如int[]),也就是说,可以传多条记录到数据,从而一起更新。减少数据库的请求次数。 但SqlServer呢?bulk Insert这
我是一名优秀的程序员,十分优秀!