gpt4 book ai didi

sql-server - 如何在 Visual Studio 数据库项目 (SSDT) 上设置更改跟踪

转载 作者:行者123 更新时间:2023-12-01 10:36:47 25 4
gpt4 key购买 nike

我有一个 SQL Server 2005 数据库项目,我希望在更高版本的 SQL Server 上的现有数据库上部署架构。我遇到的问题是更改跟踪在我希望部署到的数据库上启用,因此 SSDT 想要做的第一件事是禁用 CT。当我收到以下错误时,这会带来问题:

(43,1): SQL72014: .Net SqlClient Data Provider: Msg 22115, Level 16,State 1, Line 5 Change tracking is enabled for one or more tables indatabase 'Test'. Disable change tracking on each table beforedisabling it for the database. Use the sys.change_tracking_tablescatalog view to obtain a list of tables for which change tracking isenabled. (39,0): SQL72045: Script execution error. The executedscript:

IF EXISTS (SELECT 1
FROM [master].[dbo].[sysdatabases]
WHERE [name] = N'$(DatabaseName)')
BEGIN
ALTER DATABASE [$(DatabaseName)]
SET CHANGE_TRACKING = OFF
WITH ROLLBACK IMMEDIATE;
END

为了解决这个问题,我创建了一个 PreDeployment 脚本来执行以下内容:

/* Run pre-deployment scripts to resolve issues */
IF(SELECT SUBSTRING(@@VERSION, 29,4)) = '11.0'

BEGIN

PRINT 'Enabling Change Tracking';

DECLARE @dbname VARCHAR(250)
SELECT @dbname = DB_NAME()

EXEC('
IF NOT EXISTS(SELECT * FROM [master].[dbo].[sysdatabases] WHERE name = ''' + @dbname + ''')

ALTER DATABASE ['+ @dbname +
']SET CHANGE_TRACKING = ON
(CHANGE_RETENTION = 5 DAYS, AUTO_CLEANUP = ON);
');

EXEC('
IF NOT EXISTS(SELECT * FROM sys.change_tracking_tables ctt
INNER JOIN sys.tables t ON t.object_id = ctt.object_id
INNER JOIN sys.schemas s ON s.schema_id = t.schema_id
WHERE t.name = ''TableName'')
BEGIN
ALTER TABLE [dbo].[TableName] ENABLE CHANGE_TRACKING;
END;');

因此,基于数据库版本更改跟踪被设置为在数据库和相关表上启用,假设它尚未启用。我从以前的帖子中得到这个想法:# ifdef type conditional compilation in T-SQL sql server 2008 2005

不幸的是,这仍然无法正常工作,因为 SSDT 试图在执行预部署脚本之前禁用更改跟踪。

最佳答案

确保在您的数据库项目中启用更改跟踪。

打开数据库项目的属性 > 项目设置 > 数据库设置... > 操作选项卡 > 检查“更改跟踪”选项

关于sql-server - 如何在 Visual Studio 数据库项目 (SSDT) 上设置更改跟踪,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34037410/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com