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

Développement SQL Server Discussion :

Echange de données entre PostgreSQL et SQL Server [2005]


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 139
    Par défaut Echange de données entre PostgreSQL et SQL Server
    Bonjour,

    Dans le cadre d'un projet, je dois récupérer des données situées sur une base Posgres SQL pour les stocker après transformation dans une base SQL SERVER.

    A l'aide d'un driver ODBC, j'exécute des requêtes depuis SQL SERVER 2005 pour récupérer les données sur Posgres. Sans surprise je constate d'énorme lenteur d'accès. Dans la mesure ou je ne peux pas passer en full posgres ou full sql server, que puis je faire pour améliorer le temps des requêtes?

    Je précise que les requêtes exécutés directement sur posgres répondent immédiatement, les écritures sur sql serveur sont faites rapidement. La requête en question doit extraire 25K de lignes dans des tables de quelques millions de lignes.

    Merci d'avance.

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 611
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Désolé, je ne sais pas répondre à cette question (sauf à demander de publier les requêtes et le DDL des tables, pour vérifier si ces requêtes sont sargables), mais je m'interroge sur la pertinence de charger une base SQL server 2005 complètement périmée.

    Voir le cycle de vie des versions SQL server ICI

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 139
    Par défaut
    Nul n'est prophète en son pays. J'ai beau signaler l'urgence de ce problème, les décideurs ne voient pas le problème (tant que ça marche pourquoi changer blablabla...).

  4. #4
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 139
    Par défaut
    La requête en question:

    Les tables T1à t3 sont des table situées sur posgres La requete est joué depuis sql server. Une source ODBC utilisant le driver posgres a été créée et montée dans les serveurs liés sql.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT T1.ID, T2.Valeur, T3.Position
    FROM Table T1
    JOIN Table T2 ON T2.ID= T1.ID
    JOIN Table T3 ON T3.ID = T2.ID
    WHERE T1.ORDER_ID  = 3
    En fait le fond du problème est que lorsque je lance
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM Table T1 WHERE T1.ORDER_ID  = 3
    , la requête distante envoyées par sql est bien la même.
    Pourtant coté Posgres, la requête jouée est .

    Ce qui signifie quelque chose , sans doute la source odbc, interprète la requête et la modifie.
    Problème, avec le filtre, 25K lignes, sans le filtres 3 millions de ligne. Je cherche donc un moyen de faire jouer mes requêtes telles que écrite.

  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 999
    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 999
    Billets dans le blog
    6
    Par défaut
    Lorsque vous faites une requête avec un serveur lié, entre deux systèmes différents, il faut faire transiter les données d'un serveur (ici PostGreSQL) à l'autre. Cela s'appelle un REMOTE JOIN. Aucune clé, aucun index ne peut être utilisé. Les données de la table PG sont copiées manière brute vers SQL Server et ce dernier créé une table pour les recevoir... Une fois que toutes les lignes en transit ont été copiées, SQL Server peut procéder à la requête, mais sans clé, sans index, elle restera toujours lente.

    Si vous voulez des performances ce n'est pas comme cela qu'il faut faire. Parmi les solutions intéressantes à tester, le recours à SSIS qui est l'ETL le plus performant du monde actuellement.

    Pour information, la version 2005 est obsolète et non supportée depuis plus de 10 ans !

    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/ * * * * *

  6. #6
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 139
    Par défaut
    Bonjour,

    merci, cela confirme ce que je pensais.

    Tout comme SQL 2005, je ne suis pas décisionnaire des choix techniques et/ou version SQL. Je n'en subit que les conséquences, malgré mes remarques...


    Merci à tous.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Envoie de données entre SQLite et SQL Server
    Par zobairfr dans le forum Windows Mobile
    Réponses: 0
    Dernier message: 28/10/2014, 10h25
  2. [TOS] Transfert de données entre 2 bdd SQL Server
    Par Teddy.Legris dans le forum Développement de jobs
    Réponses: 0
    Dernier message: 30/09/2013, 08h42
  3. Echange de données entre Windows Mobile 6.1 et Windows Server 2008
    Par gibsonSG_76 dans le forum Windev Mobile
    Réponses: 0
    Dernier message: 16/04/2012, 16h04
  4. Transférer données entre deux tables sql server
    Par Aethen dans le forum Langage SQL
    Réponses: 2
    Dernier message: 31/05/2011, 14h52
  5. [AC-2007] Transfer de données entre Access et SQL server
    Par yonnel dans le forum Projets ADP
    Réponses: 4
    Dernier message: 22/12/2010, 15h23

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