Accueil > > > CAPTURE DES CHANGEMENTS DE DONNÉES (CDC: CHANGE DATA CAPTURE)
CAPTURE DES CHANGEMENTS DE DONNÉES (CDC: CHANGE DATA CAPTURE)
Information sur la source
Description
Change Data Capture (CDC) est une nouvelle fonctionnalité intégrée à SQL Server 2008 et qui permet de détecter et récupérer les changements effectués sur une base de données On peut activer CDC pour récupérer les changements effectués sur une table donnée et les mettres dans une table spécifique qui contient les colonnes suivantes : type de changement (insertion, modification ou suppression) et le changement réellement effectué (l'enregistrement et les colonnes modifiées). ce qui nou permettra de suivre les modifications (ajout, modification, supprerssion des enregistrement)sur une table donnée.
Source
- 'Activer CDC :
-
- 'Avant d'activer CDC sur une table, il
- ' faudra activer CDC pour la base de
- ' données :
-
- USE AdventureWorks
-
- GO
-
- EXECUTE sys.sp_cdc_enable_db_change_data_capture;
-
- GO
-
- 'Voici un exemple d'un script permettant
- 'l'activation du CDC sur la table
- 'SalesPerson de AdventureWorks
-
- USE AdventureWorks
-
- EXEC sys.sp_cdc_enable_table_change_data_capture
-
- @source_schema = 'Sales',
-
- @source_name = 'SalesPerson',
-
- @supports_net_changes = 1,
-
- @role_name = NULL
-
- 'Dés que ce script est exécuté une table
- 'sera automatiquement crée dans le schéma CDC, dans notre cas
- 'cdc.Sales_Salespeople_CT cette table en
- 'plus des colonnes de la table
- 'SalesPerson elle contient un ensemble
- 'd'autre colonnes identifiant et
- 'décrivant le changement. Des fonctions
- 'sont aussi ajouté pour permettre de
- 'requêter la table des changements
- 'cdc.Sales_Salespeople_CT.
-
- 'Vous pouvez après faire une simulation
- 'en faisant des
- 'insertions/modification/suppression et
- 'voir les effets que vos modifications
- 'auront sur la table
- ' cdc.Sales_Salespeople_CT :
-
- INSERT INTO [AdventureWorks].[Sales].[SalesPerson]
-
- ([SalesPersonID],[TerritoryID],[SalesQuota],[Bonus],[CommissionPct],[SalesYTD])
-
- VALUES(1,9,250000,5650,0.01,225000)
-
- GO
-
- UPDATE [AdventureWorks].[Sales].[SalesPerson]
-
- SET [TerritoryID] = 10
-
- WHERE [SalesPersonID]=290
-
- GO
-
- DELETE FROM [AdventureWorks].[Sales].[SalesPerson]
-
- WHERE [SalesPersonID]=1
-
- GO
-
- 'Notter qu'on a insérer puis supprimer
- 'l'enregistrement
- '(1,9,250000,5650,0.01,225000).
-
-
- 'Comment récupérer les changements ?
-
- 'On peut récupérer les changement tout
- 'simplement avec une requette Select sur
- 'la table cdc.Sales_Salespeople_CT ou en
- 'utilisant les fonctions crées.
-
- 'Exemple :
-
- DECLARE @from_lsn binary(10);
-
- DECLARE @to_lsn Binary(10);
-
- SELECT @from_lsn = sys.fn_cdc_map_time_to_lsn('smallest greater than or equal', '03-01-2008');
-
- SELECT @to_lsn = sys.fn_cdc_map_time_to_lsn('largest less than or equal', '03-12-2008');
-
- SELECT * FROM cdc.fn_cdc_get_all_changes_Sales_SalesPerson
-
- ((SELECT MIN(HRCDC.__$start_lsn) from cdc.Sales_SalesPerson_CT HRCDC WHERE __$start_lsn>=@from_lsn ),
-
- (SELECT MAX(HRCDC.__$start_lsn) from cdc.Sales_SalesPerson_CT HRCDC WHERE __$start_lsn<=@to_lsn ),'ALL');
-
'Activer CDC :
'Avant d'activer CDC sur une table, il
' faudra activer CDC pour la base de
' données :
USE AdventureWorks
GO
EXECUTE sys.sp_cdc_enable_db_change_data_capture;
GO
'Voici un exemple d'un script permettant
'l'activation du CDC sur la table
'SalesPerson de AdventureWorks
USE AdventureWorks
EXEC sys.sp_cdc_enable_table_change_data_capture
@source_schema = 'Sales',
@source_name = 'SalesPerson',
@supports_net_changes = 1,
@role_name = NULL
'Dés que ce script est exécuté une table
'sera automatiquement crée dans le schéma CDC, dans notre cas
'cdc.Sales_Salespeople_CT cette table en
'plus des colonnes de la table
'SalesPerson elle contient un ensemble
'd'autre colonnes identifiant et
'décrivant le changement. Des fonctions
'sont aussi ajouté pour permettre de
'requêter la table des changements
'cdc.Sales_Salespeople_CT.
'Vous pouvez après faire une simulation
'en faisant des
'insertions/modification/suppression et
'voir les effets que vos modifications
'auront sur la table
' cdc.Sales_Salespeople_CT :
INSERT INTO [AdventureWorks].[Sales].[SalesPerson]
([SalesPersonID],[TerritoryID],[SalesQuota],[Bonus],[CommissionPct],[SalesYTD])
VALUES(1,9,250000,5650,0.01,225000)
GO
UPDATE [AdventureWorks].[Sales].[SalesPerson]
SET [TerritoryID] = 10
WHERE [SalesPersonID]=290
GO
DELETE FROM [AdventureWorks].[Sales].[SalesPerson]
WHERE [SalesPersonID]=1
GO
'Notter qu'on a insérer puis supprimer
'l'enregistrement
'(1,9,250000,5650,0.01,225000).
'Comment récupérer les changements ?
'On peut récupérer les changement tout
'simplement avec une requette Select sur
'la table cdc.Sales_Salespeople_CT ou en
'utilisant les fonctions crées.
'Exemple :
DECLARE @from_lsn binary(10);
DECLARE @to_lsn Binary(10);
SELECT @from_lsn = sys.fn_cdc_map_time_to_lsn('smallest greater than or equal', '03-01-2008');
SELECT @to_lsn = sys.fn_cdc_map_time_to_lsn('largest less than or equal', '03-12-2008');
SELECT * FROM cdc.fn_cdc_get_all_changes_Sales_SalesPerson
((SELECT MIN(HRCDC.__$start_lsn) from cdc.Sales_SalesPerson_CT HRCDC WHERE __$start_lsn>=@from_lsn ),
(SELECT MAX(HRCDC.__$start_lsn) from cdc.Sales_SalesPerson_CT HRCDC WHERE __$start_lsn<=@to_lsn ),'ALL');
Conclusion
Ce script récupère les changement effectués sur notre table du 01 au 12 mars 2008. La fonction fn_cdc_get_all_changes_…. permet de récupérer l'ensemble des modifications effectuées, dans notre exemple les trois opérations qu'on effectués sur la table SalesPerson.
Par contre fn_cdc_get_net_changes_….permet de récupérer les changement nettes (effectives). Dans notre exemple le changement effective est une seule modification car on a insérer puis supprimer l'enregistrement dont le SalesPersonID=1.
en combinant CDC avec proactive-caching et les nouveautés Datawarehousing de SQL Server 2008, ouvre les portes à une BI en temps réel avec synchronisation des changements à partir des bases opérationnelles vers le datawarehouse.
Historique
- 22 janvier 2009 20:20:53 :
- mise en forme du source
- 17 janvier 2012 10:19:01 :
- Complément d'explication
- 17 janvier 2012 10:25:20 :
- Complément d'explication
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Somme problématique : perte de ligne [ par ALLODREN ]
Bonjour, Je cherche à concaténer le px_com des lignes qui ont un nucdli=nu_docu. Affecter la somme dans le champ px_com dans la ligne qui a un nu_do
|
Derniers Blogs
SIMULER FACILEMENT L'ENVOI DE MAILSIMULER FACILEMENT L'ENVOI DE MAIL par JeremyJeanson
il m'a été demandé, à plusieurs reprises, comment je faisais pour simuler l'envoi de mail lors de mes démos de Workflow Foundation. Ma solution est plutôt simple : j'utilise la configuration par défaut du SmtpClient et j'oriente les mails vers un dossier ...
Cliquez pour lire la suite de l'article par JeremyJeanson VOTEZ POUR LE TOP 10 DES INFLUENCEURS SHAREPOINT FRANCOPHONES !VOTEZ POUR LE TOP 10 DES INFLUENCEURS SHAREPOINT FRANCOPHONES ! par Patrick Guimonet
Si ce n'est déjà fait (comme plus de 600 personnes déjà), il est encore temps de voter pour le concours TOP 10 des influenceurs SharePoint francophones ! Il est organisé par harmon.ie et accessible ici : http://harmon.ie/top-...
Cliquez pour lire la suite de l'article par Patrick Guimonet [CONF'SHAREPOINT] DERNIER RAPPEL ! :-)[CONF'SHAREPOINT] DERNIER RAPPEL ! :-) par Patrick Guimonet
La Conf'SharePoint en chiffres c'est : 3 jours de SharePoint ! 4 parcours et 60 sessions 17 partenaires représentant toutes les fac...
Cliquez pour lire la suite de l'article par Patrick Guimonet [ #SHAREPOINT 2013 ] LES MODèLES DE SITES STANDARDS.[ #SHAREPOINT 2013 ] LES MODèLES DE SITES STANDARDS. par Patrick Guimonet
C'est un point peu mis en avant mais SharePoint 2013 a été l'occasion de remettre de l'ordre dans les modèles de sites. Tout d'abord, un certain nombre de modèles ont été tout simplement rendus obsolètes (cf. Fonctionnalités déco...
Cliquez pour lire la suite de l'article par Patrick Guimonet
Forum
BESOIN D'AIDE BESOIN D'AIDE par dzservers
Cliquez pour lire la suite par dzservers
Logiciels
Easy-Planning (4.5.0.11)EASY-PLANNING (4.5.0.11)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté a... Cliquez pour télécharger Easy-Planning CVEasy (3.1.0.51)CVEASY (3.1.0.51)PHMSD-CVEasy est un logiciel d'aide à la rédaction de CV d'une simplicité déconcertante.
PHMSD-C... Cliquez pour télécharger CVEasy LettresFaciles 2011 (8.6.0.31)LETTRESFACILES 2011 (8.6.0.31)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011 sDEVIS-FACTURES vlPRO (8.4.2.62)SDEVIS-FACTURES VLPRO (8.4.2.62)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO Devis-Factures PHMSD (2.1.0.11)DEVIS-FACTURES PHMSD (2.1.0.11)Configuration minimale
Nécessite Windows™ 2000, XP, Windows 7, 8, Vista (Service Pack à... Cliquez pour télécharger Devis-Factures PHMSD
|