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

Réplications SQL Server Discussion :

Replication ou autre procédé SQL


Sujet :

Réplications SQL Server

  1. #1
    Membre actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2007
    Messages
    193
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2007
    Messages : 193
    Points : 213
    Points
    213
    Par défaut Replication ou autre procédé SQL
    Bonjour,

    J'ai un petit soucis de conception de projet.

    J'ai un projet (qui était en production et marchait très bien jusqu'a présent) qui consiste a copier des données d'une base de donnée vers une autre. Les bases de données sont toutes des sql server 2005 standard (sp3)

    J'utilisais un système un peu particulier mais qui pour un volume important de donnée s'est révélé bien trop lent.
    Principe :

    Trigger sur une table sur un insert ou update ou delete, qui ajoute la commande avec les données dans une table dites "journal", replication de cette table sur mes bases de donnée distante, exécution des requètes inscrites dans le journal par le serveur distant sur le serveur distant.

    Problème rencontrés : Le système de copie dans la table de journal est rapide (en tout cas suffisante), la copie du journal via replication est correct (je rencontre quelques petits soucis sur la replication mais c'est un autre sujet), l'exécution des requètes est excessivement lent. Il me faudrait un autre procédé.

    Problème rencontré :

    Il me faut une sélection par ligne (jusque la je peux tout faire en réplication), il me faut une sélection par colonne, les 2 tables auront la même structure mais lors de la copie, modification de donnée, le serveur ne touchera a aucune donnée dans les colonnes non sélectionnées. Et pour certaines de mes colonnes non sélectionnées je dois pouvoir indiquer une valeur par défaut sur l'insert. (La je perds la replication, ou je ne la connais pas suffisament.... il est sur que j'ai des grosses défaillance en réplication).


    Voilà donc mon problème, quel technique sql server ai je d'exploitable? Je dois donc faire depuis le serveur des inserts/update/delete sur un autre serveur avec une limitation par ligne, par colonne avec possibilité de mettre des champs calculés.

    Petit détail aussi, lorsque je change la configuration vu que j'ai un choix de colonne ne pas tout supprimer dans les tables.

    Merci d'avance pour votre aide

  2. #2
    Membre confirmé Avatar de agemis31
    Profil pro
    DBA
    Inscrit en
    Octobre 2007
    Messages
    399
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : DBA

    Informations forums :
    Inscription : Octobre 2007
    Messages : 399
    Points : 478
    Points
    478
    Par défaut
    Bonjour,

    Je ne suis expert en réplication , loin de la, mais il me semble que sélection des colonnes répliquées ne pose pas de problème.

    Pour l'insert, je ne vois pas le problème, si c'est vraiment complexe, vous pouvez définir un trigger, et eviter de l'écraser si vous en avez déja un sur votre table source en utilisant NOT FOR REPLICATION.

    @+

  3. #3
    Membre actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2007
    Messages
    193
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2007
    Messages : 193
    Points : 213
    Points
    213
    Par défaut
    Bonjour,

    Oui il semblerait que j'aie intéret a améliorer mon système via trigger.

    La réplication en supprimant des colonnes va me poser problème car je veux ne pas toujours copîer le contenu de colonne "NOT NULL" et il me faut une valeur par défaut pour une replication, mais une autre valeur par défaut pour une autre replication.

    Question sur le NOT FOR REPLICATION, il ne s'applique pas a une colonne d'une table si? (hormis identité bien sur)

  4. #4
    Membre confirmé Avatar de agemis31
    Profil pro
    DBA
    Inscrit en
    Octobre 2007
    Messages
    399
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : DBA

    Informations forums :
    Inscription : Octobre 2007
    Messages : 399
    Points : 478
    Points
    478
    Par défaut
    Bonsoir,

    Non je ne crois pas. Je crois qu'il faut filtrer les colonnes dans les propriétés des articles.

    @+

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 897
    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 897
    Points : 53 135
    Points
    53 135
    Billets dans le blog
    6
    Par défaut
    Dans votre cas il serait souhaitable d'utiliser service broker pour faire la partie transport plutôt que de la réplication.

    A +

Discussions similaires

  1. Réponses: 8
    Dernier message: 27/01/2007, 13h44
  2. Copier DB dans une autre (en SQL)
    Par Pill_S dans le forum Administration
    Réponses: 14
    Dernier message: 01/09/2006, 21h13
  3. Picking ou autres procédés?
    Par wystan dans le forum OpenGL
    Réponses: 6
    Dernier message: 17/07/2006, 13h42
  4. Requete SQL sur le resultat d'un autre Requete SQL
    Par Redsky dans le forum Bases de données
    Réponses: 8
    Dernier message: 02/08/2005, 11h55
  5. connexion d'une bd d'un serveur sql à un autre serveur sql
    Par kayser dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 29/07/2005, 12h43

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