El cdc es una feature muy buena del SQL2008 visto que de forma sencilla nos permite llevar un registro de los cambios en una tabla, tanto sea para cuestiones de auditoría, procesamientos parciales de información, etc.
Así mismo, cuando se trabaja con cdc es normal que se deseen probar, testear, desarrollar procedimientos que utilicen esta información y naturalmente no queremos que accedan al ambiente productivo hasta estar testeadas. Aquí es cuando nos topamos que si hacemos un restore de una base con cdc en otra instancia no aparecen las tablas correspondientes. Para evitar esto debemos incluir la opción WITH KEEP_CDC al momento de hacer restore. No se si será poco usada, pero no se asusten si no es coloreada en el Managment Studio, funciona a la perfección.
El código debería quedar algo así:
RESTORE DATABASE [AIELLO_DB] FROM DISK = N'D:\Backup\[AIELLO_DB][SQL2008].bak' WITH KEEP_CDC, FILE = 1, MOVE N'AIELLO_DB' TO N'D:\MSSQL10.MSSQLSERVER\MSSQL\DATA\AIELLO_DB.mdf', MOVE N'AIELLO_DB_log' TO N'D:\MSSQL10.MSSQLSERVER\MSSQL\DATA\AIELLO_DB_log.ldf', MOVE N'AIELLO_DB_cdc' TO N'D:\MSSQL10.MSSQLSERVER\MSSQL\DATA\AIELLO_DB_cdc.ndf', NOUNLOAD, REPLACE, STATS = 10
Con esto tendrán la información para poder explotarla, pero no se activará la captura de datos. Si desean que esto ocurra hay que incluir los jobs correspondientes con sys.sp_cdc_add_job aplicando tanto 'capture' como 'cleanup'.
Saludos,
Andrés
Para mas información:
RESTORE Arguments (Transact-SQL): http://msdn.microsoft.com/en-us/library/ms178615.aspx
sys.sp_cdc_add_job (Transact-SQL): http://msdn.microsoft.com/en-us/library/bb510626.aspx