IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MS SQL Server Discussion :

Historique des modifications


Sujet :

MS SQL Server

  1. #1
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut Historique des modifications
    Bonjour,

    Nous cherchons à avoir un historique des modifications pour la plupart des colonnes de notre base, dans une table du type :
    Identity, IdColonne, DateHeure, IdUser, Valeur
    (ca ne prend pas trop de place et c'est facile à interroger)
    Ceci doit fonctionner sur sql2012 standard (donc pas de cdc/change tracking à priori(on m'a dit que c'était sur entreprise seulement)) et idéalement sur express

    Tout part donc d'un (ou pluseurs) trigger sur chaque table à gérer, et pour ne pas ralentir les applis nous voudrions en faire le maximum en asynchrone.
    ce qu'on faisait pour l'instant, c'est une table d'historique pour chaque table, le trigger insert la table inserted dans la table d'historique (l'insert brut étant rapide) et un thread .net dépile ce qu'il y a dans ces tables pour remplir la table finale (suppressions des doublons vu que souvent une seule colonne est modifiée ...)

    Trigger asynchrone je ne pense pas que ca existe, trigger CLR ca semble lent sur nos premiers tests, donc je cherche idéalement un moyen de faire tenir inserted et deleted de toutes mes tables dans une seule table
    le nombre/type de colonnes étant différent d'une table à l'autre il faudrait un moyen de "sérialiser" tout ca dans une seule colonne/valeur et rapidement ...

    Sinon je suis ouvert à toute suggestion.

    Merci.
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 768
    Points : 52 719
    Points
    52 719
    Billets dans le blog
    5
    Par défaut
    Change Tracking répond parfaitement à vos besoin et est disponible dès la version Express !
    https://msdn.microsoft.com/en-us/lib...px#Replication

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    désolé de te contredire
    Citation Envoyé par msdn
    Change Tracking
    Change tracking captures the fact that rows in a table were changed, but does not capture the data that was changed. This enables applications to determine the rows that have changed with the latest row data being obtained directly from the user tables. Therefore, change tracking is more limited in the historical questions it can answer compared to change data capture. However, for those applications that do not require the historical information, there is far less storage overhead because of the changed data not being captured. A synchronous tracking mechanism is used to track the changes. This has been designed to have minimal overhead to the DML operations.
    c'est le change data capture qui peut faire ca bien, et il n'est dispo que sur entreprise et developper edition
    le change tracking sert surtout à faire du mirroring à la main ...
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 768
    Points : 52 719
    Points
    52 719
    Billets dans le blog
    5
    Par défaut
    non... CT permet de savoir ce qui a évolué. Par de savoir la valeur avant. Il suffit que vous ayiez les valeurs de départ pour avoir la valeur avant.
    Le mirroring est basé sur l'application binaires de modification de pages dans le JT (transactions physiques) et non sur des transactions logiques.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    si je ne m'abuse le CT nous dit qu'il y a eut un changement si on l'interroge
    or moi je peux avoir des valeurs qui changent très vite, donc je ne veux pas en rater une
    c'est pour ca qu'il me faudrait une solution synchrone (la complexité d'écriture ne me dérange pas)
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

Discussions similaires

  1. [MCD] Historique des modifications
    Par chris78 dans le forum Schéma
    Réponses: 2
    Dernier message: 03/04/2009, 18h26
  2. historique des modifications
    Par linuxxp dans le forum Langage SQL
    Réponses: 2
    Dernier message: 23/02/2009, 07h24
  3. modification de donnée avec historique des modifications
    Par frans_2000 dans le forum Modélisation
    Réponses: 2
    Dernier message: 30/12/2007, 12h10
  4. Réponses: 4
    Dernier message: 06/10/2006, 15h24
  5. historique des modifications oracle
    Par Titibirdy dans le forum Oracle
    Réponses: 4
    Dernier message: 07/06/2006, 17h14

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo