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 dans une table spécifique qui contient le type de changement (insertion, modification ou suppression) et le changement réellement effectué (l'enregistrement et les colonnes modifiées).
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
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
[WINDOWSPHONE7] LECTEUR DE FLUX RSS[WINDOWSPHONE7] LECTEUR DE FLUX RSS par Vko
Parce que j'aime pas tester à moitié, je me suis amusé à développer un petit lecteur de flux RSS avec un look qui vous rappellera surement quelque chose :) La RC de Visual Studio est plutôt molle mais fonctionne correctement. L'émulateur est pas...
Cliquez pour lire la suite de l'article par Vko [WP7] L'éMULATEUR WINDOWS PHONE 7 EST MULTITâCHE[WP7] L'éMULATEUR WINDOWS PHONE 7 EST MULTITâCHE par KooKiz
Une question qui reste en suspend concernant Windows Phone 7 est de savoir si le système permettra à plusieurs applications de s'exécuter simultanément, ou si un système de mise en pause similaire à celui de l'iPhone sera adopté. Même si cela ne perm...
Cliquez pour lire la suite de l'article par KooKiz PRéSENTATION CLUB MOSS CE JOUR "LA NOUVELLE ARCHITECTURE DE SERVICES SHAREPOINT 2010".PRéSENTATION CLUB MOSS CE JOUR "LA NOUVELLE ARCHITECTURE DE SERVICES SHAREPOINT 2010". par Patrick Guimonet
Ca y est la sortie RTM de SharePoint 2010 est annoncée pour le 16 avril 2010 (annonce faite ce jour par Erol Giraudy lors de la réunion du club MOSS). Vous pourrez trouver ici les slides de ma présentation du jour dans le cadre du club MOSS : 201...
Cliquez pour lire la suite de l'article par Patrick Guimonet [WINDOWPHONE7] PREMIERS PAS[WINDOWPHONE7] PREMIERS PAS par Vko
Hop voici les premiers pas avec les outils de développement pour Windows Phone 7. Premier changement suite à l'installation des outils : les type de projets pour la plateforme Windows Phone 7. Les projets se découpent en deux groupes : Les projet...
Cliquez pour lire la suite de l'article par Vko [WP7] LE SDK DE WINDOWS PHONE 7 EST DISPONIBLE ![WP7] LE SDK DE WINDOWS PHONE 7 EST DISPONIBLE ! par KooKiz
Comme le titre l'indique, une première CTP du kit de développement pour Windows Phone 7 est disponible. Basé sur Visual Studio 2010 Express, il propose de développer des applications pour WP7 en Silverlight ou XNA 4. Un émulateur est bien entendu de l...
Cliquez pour lire la suite de l'article par KooKiz
Forum
MCDMCD par debinfo
Cliquez pour lire la suite par debinfo
Logiciels
Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods Konvertor (4.00)KONVERTOR (4.00)Le logiciel est un gestionnaire multimedia affichant, jouant et convertissant plus de 2000 format... Cliquez pour télécharger Konvertor
|