tag(s) Tags: SQL Server 2008
lu 673 fois
7 pages
Jean-Pierre Riehl
SQL Server 2008 : Change Data Capture
Présentation d'une des nouvelles fonctionnalités de SQL Server 2008, le Change Data Capture
Par Jean-Pierre Riehl publié le 25/02/2008 à 00:20
 
Comme beaucoup de fonctionnalités depuis SQL Server 2005, la première étape est d'activer le Change Data Capture (CDC). On l'active au niveau de la base de données via une procédure stockée système :

Exec sys.sp_cdc_enable_db_change_data_capture

Pour savoir si votre base est déjà prête pour le CDC, il suffit de requêter le champ is_cdc_enabled de la vue système des bases de données sys.databases :

Select name, is_cdc_enabled

From sys.databases

L'activation du CDC ne change pas seulement ce flag mais crée tout un ensemble d'objets dans la base de données pour gérer la fonctionnalité.
 
/content/e26e5100-4442-4e16-b364-170430af6089/cdc-system-tables.png
 
Ces objets sont créés dans le schéma cdc ce qui permet de les masquer aux simples utilisateurs de votre base et de les protéger.
Note : si un schéma ou un utilisateur nommé cdc existe déjà, l'activation du CDC est impossible car cdc est un mot réservé ; il faut juste le savoir.
Une fois la base prête, il faut enregistrer une table à surveiller. Cela se fait aussi par une procédure stockée système : sys.sp_cdc_enable_table_change_data_capture. On doit préciser la table (schéma et nom) et un rôle avec lequel le système va atteindre la table. On peut préciser des options pour tirer partie des fonctionnalités avancées du CDC ; ces fonctions seront décrites plus en avant dans l'article.

exec sys.sp_cdc_enable_table_change_data_capture

    @source_schema = 'Sales',

    @source_name = 'SalesOrderHeader',

    @role_name = 'datacapture'

L'appel de cette procédure système crée aussi des objets dans la base de données, le fonctionnement de ces objets est décrit plus loin :
  • Une table( cdc.Sales_SalesOrderHeader_CT) qui est une copie de la table enregistrée mais avec des champs techniques en plus, on l'appelle la change table
  • Des procédures stockées : sp_insdel_<id> et sp_upd_<id>
  • Des fonctions : fn_cdc_get_all_changes_<captureinstance>
 
/content/e26e5100-4442-4e16-b364-170430af6089/cdc-system-functions.png
 
Ce qu'il est important de comprendre, c'est la notion d'instance de capture. Lorsque l'on enregistre une table au CDC, on crée une instance de capture sur cette table. Cette instance de capture sera utilisée dans les différentes opérations relatives au CDC, il est donc important de connaître son nom. Par défaut, il est constitué du schéma et du nom de la table enregistrée, ex : Sales_SalesOrderHeader. Pour le personnaliser, on doit le fournir à l'enregistrement de la table.
Comme pour la base de données, on peut savoir si une table est déjà enregistrée en requêtant les vues systèmes :

Select name, is_tracked_by_cdc

From sys.tables

On peut restreindre la capture à une liste définie de colonnes de la table. Par défaut, toutes les colonnes sont incluses dans la capture. Si on décide de réduire le nombre de colonnes incluses, il faut obligatoirement inclure un index unique ou la clé primaire pour que le CDC puisse identifier de façon unique l'enregistrement modifié.
La liste des colonnes se passe à la procédure d'enregistrement de la table au CDC :

exec sys.sp_cdc_enable_table_change_data_capture

    […]

    , @captured_column_list = 'salesorderid,status';

Attention, il y a des noms de colonnes réservés mais vu leur format (__$xxx), je doute que la plupart d'entre nous soit concerné.
On peut préciser de stocker les changements capturés dans un groupe de fichiers séparé. Pour cela, on le précise à l'enregistrement de la table pour le CDC.

exec sys.sp_cdc_enable_table_change_data_capture

    […]

    , @filegroup_name = N'PRIMARY';

Chaque entité peut être suivie par 2 captures différentes. Pour cela, on identifie chaque capture au moment de sa mise en place avec le paramètre optionnel @capture_instance. Par défaut, le nom de la capture est schema_table (ex : dbo_simpletable).

 Commentaire - SQL Server 2008 : Change Data Capture 

 Dernières Publications      

Exploiter les données CSV via Linq en toute simplicité
  A partir du requêteur dynamique fourni en exemple avec Visual Studio 2008, nous allons essayer de remplir les propriétés d'un ensemble d'objets à partir des données d'un fichier CSV. Nous enrichirons aussi le parseur de nos propres fonctions.
par Frédéric Mélantois posté le 17/05/2008 à 11:41, lu 138 fois, #0
Polymorphisme et contrats de données WCF
  WCF aborde les types polymorphes du point de vue de la sérialisation. En effet, la connaissance du type réel potentiel est rendue nécessaire dès la description du contrat de données. Une fois n'est pas coutume, j'ai réalisé l'exemple en VB.NET.
par Frédéric Colin posté le 14/05/2008 à 08:40, lu 296 fois, #2
A la découverte de BizTalk Server 2006 3/3
  Développer un assembleur pour BizTalk Server 2006 R2
par Kader Yildirim posté le 06/05/2008 à 13:20, lu 147 fois, #0
Chapitre III : Sync Services for ADO.NET et WCF
   Suite des deux premiers chapitres sur la synchronisation avec Sync Services for ADO.NET, voici un nouvel article impliquant WCF dans une synchronisation déconnectée.
Requêtes dynamiques sur les IEnumerable
  A partir d'un exemple fourni avec Visual Studio 2008, initialement prévu pour tout objet Queryable, nous allons présenter comment en ajoutant très peu de code rendre disponible aux IEnumerable un requêteur dynamique.
par Frédéric Mélantois posté le 24/04/2008 à 15:03, lu 842 fois, #0
Développer une visionneuse d'images avec WPF et WCF
  Au travers de cet article, nous allons découvrir comment mettre en place une visionneuse d'images, grâce aux technologies WPF et WCF.
par Thomas Lebrun posté le 22/04/2008 à 22:46, lu 1004 fois, #2
LINQRoleProvider
  L'objectif de cet article est d'implémenter un fournisseur de rôles ASP.NET personnalisé à l'aide de LINQ To Sql tout en faisant un tour d'horizons de la syntaxe des requêtes LINQ.
par Antoine Griffard posté le 13/04/2008 à 22:18, lu 491 fois, #4
WCF : Transfert de messages streamés et sécurisation personnalisée
  Je poursuis ma série d'articles sur WCF en vous présentant cette fois-ci le mode de communication Streamé. Histoire d'aller un petit peu plus loin, j'ai protégé le service de manière personnalisée et utilisé un binding très courant : BasicHttpBinding
par Frédéric Colin posté le 07/04/2008 à 08:12, lu 884 fois, #0

 Dernières Actualités      

Injection de code et API de profiling .NET
  Si vous êtes intéressés par la sécurité du Framework, par le reverse engineering et la manipulation/injection de code .NET et les packers, alors jetez un coup d’œil...
NDepend pour l'analyse statique de code .NET
  Pour ceux qui ne connaissent pas NDepend , il s’agit d’un outil d’analyse statique de code .NET qui permet de remonter des informations à toute une équipe de développement. NDepend aide à travailler sur...
Tags: Outils
Microsoft met à disposition son IoC Container Unity 1.0 en version finale
  Microsoft met à disposition la version 1.0 de son IoC container Unity, sur CodePlex sous la forme d'un Application Block des Enterprise Library. Si vous voulez en savoir plus sur le sujet en .NET je vous...
Tags: Application Block
Microsoft MVP (Most Valuable Professional) sur Tech Head Brothers
  Je voudrais féliciter les nouveaux Microsoft MVP (Most Valuable Professional) du mois d'Avril 2008 qui publient sur Tech Head Brothers! Sans les auteurs le site ne serait rien. Sébastien Pertus - MVP SQL...
Les Webcasts des Microsoft TechDays 2008 sont en ligne
  Si vous avez participé ou non au Microsoft TechDays 2008 vous avez certainement manqué certaines présentation qui vous intéressaient. Voilà enfin votre chance de pouvoir suivre ces présentations en ligne...
Rapide résumé de la conférence MIX08
  La conférence MIX08 s'est achevée la semaine dernière avec peu d'annonces de nouvelles technologies (DeepZoom) mais surtout des releases de produits (et c'est pas un mal...). Nous avons donc eu droit aux...