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
SESSION SILVERLIGHT 5 3D : SLIDES ET DEMOSSESSION SILVERLIGHT 5 3D : SLIDES ET DEMOS par Groc
Durant les techdays, j'ai eu le plaisir d'animer une session sur Silverlight 5 et la 3D avec Simon Ferquel. Comme promis, voici nos slides et mes démos (celles avec le viper BSG) ici et là. Pour mémoire, les démos utilisent toutes le viper BSG...
Cliquez pour lire la suite de l'article par Groc [TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES[TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES par gpommier
Suite à la session que j'ai présenté sur WebMatrix 2, vous pouvez trouver les slides ici, ainsi que les démos en packages nuget : démos1 et démos2 J'en profite pour remercier chaleureusement tous ceux qui sont venus très nombreux à cette sess...
Cliquez pour lire la suite de l'article par gpommier [SHAREPOINT] LES SESSIONS TECHDAYS 2012.[SHAREPOINT] LES SESSIONS TECHDAYS 2012. par Patrick Guimonet
Voici donc pour ceux qui n'ont pas pu venir, ou ceux qui n'ont pas pu toutes les suivre la liste des sessions SharePoint aux TechDays 2012, que je mettrais à jour dès que les liens des vidéo seront disponibles. Ou ici : http...
Cliquez pour lire la suite de l'article par Patrick Guimonet TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko
Forum
BESOIN D'UN BIBESOIN D'UN BI par michimichid
Cliquez pour lire la suite par michimichid
Logiciels
Tribler (2012)TRIBLER (2012)Tribler est un client pair à pair (P2P/Peer-to-Peer) open source avec la capacité de regarder des... Cliquez pour télécharger Tribler OneSwarm (2012)ONESWARM (2012)Le peer-to-peer qui protège votre vie privée, c'est OneSwarm.
Ce logiciel de peer-to-peer crypté... Cliquez pour télécharger OneSwarm PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning
|