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

Requêtes et SQL. Discussion :

Requete ACCESS trop lente par rapport a SQL SERVER 2005


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 190
    Points : 59
    Points
    59
    Par défaut Requete ACCESS trop lente par rapport a SQL SERVER 2005
    Bonjour,

    j'aimerai savoir pourquoi le temps de réponse d'une même requete diffère (largement) selon SQL SERVER 2003 ou ACCESS 2003.

    Avec SQL, j'ai un bout de code qui demande 8 secondes.
    Avec ACCESS, je peux attendre parfois plus de 10 minutes.


    Voici mon code en SQL
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT TOP 5 a.TdProdDate, b.E_BALANCE_AMT, b.E_CUSTOMER_NAME, c.P_CACS_STATE_CODE
     
    FROM (table1 as a LEFT JOIN table2 as b ON (a.C_ACCOUNT_NUMBER = b.E_ACCT_NUM) AND (a.TdProdDate = b.TdProdDate))
    LEFT JOIN table3 as c ON (a.C_ACCOUNT_NUMBER = c.P_ACCT_NUM) AND (a.TdProdDate = c.TdProdDate)
     
    WHERE C_ACTIVITY_DATE = '20101201'
     
    ORDER BY NewID()
    Voici mon code en ACCESS :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT TOP 5 a.TdProdDate, b.E_BALANCE_AMT, b.E_CUSTOMER_NAME, c.P_CACS_STATE_CODE
     
    FROM (table1 as a LEFT JOIN table2 as b ON (a.C_ACCOUNT_NUMBER = b.E_ACCT_NUM) AND (a.TdProdDate = b.TdProdDate))
    LEFT JOIN table3 as c ON (a.C_ACCOUNT_NUMBER = c.P_ACCT_NUM) AND (a.TdProdDate = c.TdProdDate)
     
    WHERE C_ACTIVITY_DATE = #12/01/2010#
     
    ORDER BY Rnd([TdProdDate])
    Pourquoi, et surtout comment améliorer cela s'il vous plait ?

  2. #2
    Rédacteur/Modérateur

    Avatar de User
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    8 260
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 8 260
    Points : 19 423
    Points
    19 423
    Billets dans le blog
    63
    Par défaut
    Salut,

    Il nous faudrait plus d'info

    Quelle quantité de données dans tes 3 tables ?

    Tes tables sont-elles liées ou non ?

    As-tu créé des index sur les champs de jointure ?

    Vous trouverez dans la FAQ, les sources ou les tutoriels, de l'information accessible au plus grand nombre, plein de bonnes choses à consulter sans modération

    Des tutoriels pour apprendre à créer des formulaires de planning dans vos applications Access :
    Gestion sur un planning des présences et des absences des employés
    Gestion des rendez-vous sur un calendrier mensuel


    Importer un fichier JSON dans une base de données Access :
    Import Fichier JSON

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 190
    Points : 59
    Points
    59
    Par défaut
    Alors,

    1/ ce sont des tables avec des milliers de records.
    2/ elles sont liées puisque je fais des LEFT JOIN entre-elles... non ?
    3/ non, je n'ai pas crée d'index. Pourquoi devrais-je puisqu'avec SQL, c'est ultra rapide ? Je ne suis pas familier avec les index..

  4. #4
    Rédacteur/Modérateur

    Avatar de User
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    8 260
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 8 260
    Points : 19 423
    Points
    19 423
    Billets dans le blog
    63
    Par défaut
    2/ elles sont liées puisque je fais des LEFT JOIN entre-elles... non ?
    Tes tables ce sont des tables attachées, contenues dans une autre base ou sont-elles dans ta base ?
    Vous trouverez dans la FAQ, les sources ou les tutoriels, de l'information accessible au plus grand nombre, plein de bonnes choses à consulter sans modération

    Des tutoriels pour apprendre à créer des formulaires de planning dans vos applications Access :
    Gestion sur un planning des présences et des absences des employés
    Gestion des rendez-vous sur un calendrier mensuel


    Importer un fichier JSON dans une base de données Access :
    Import Fichier JSON

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 190
    Points : 59
    Points
    59
    Par défaut
    Ces 3 tables sont dans une Data WareHouse.
    Je fais appel à ces tables, avec des liens vers ces dernières.

  6. #6
    Rédacteur/Modérateur

    Avatar de User
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    8 260
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 8 260
    Points : 19 423
    Points
    19 423
    Billets dans le blog
    63
    Par défaut
    Donc ce sont ce que l'on appelle des "tables liées", ta base access possèdes des références vers ces données probablement stockées sur 1 serveur ce qui ralenti notablement l'accès et la manipulation de ces données distantes...
    Vous trouverez dans la FAQ, les sources ou les tutoriels, de l'information accessible au plus grand nombre, plein de bonnes choses à consulter sans modération

    Des tutoriels pour apprendre à créer des formulaires de planning dans vos applications Access :
    Gestion sur un planning des présences et des absences des employés
    Gestion des rendez-vous sur un calendrier mensuel


    Importer un fichier JSON dans une base de données Access :
    Import Fichier JSON

  7. #7
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonsoir,

    Si un accès en lecture seule convient à ton application, tu peux t'orienter vers des requêtes de type SQL Direct.
    Ces requêtes devrons être écrite en SQL transact-Sql (le SQL de SQL Server).

    Contrairement à une requête Access sur des tables liées (tables SQL Server liées par ODBC),
    une requête SQL Direct est exécutée par le serveur du SGBD.

    Sinon, je ne vois que des recordsets et une connexion ADODB au serveur SQL server.

    A+

Discussions similaires

  1. Requete Access : Max date par personne
    Par snoopy92 dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 06/07/2011, 09h01
  2. [java.nio] lecture un peu trop lente par rapport à un BufferedReader
    Par entreprise38 dans le forum Débuter avec Java
    Réponses: 1
    Dernier message: 15/12/2008, 17h06
  3. Réponses: 5
    Dernier message: 10/12/2007, 15h24
  4. Requete access - Trop peu de paramètres
    Par jmulans dans le forum ASP
    Réponses: 2
    Dernier message: 29/03/2007, 11h55
  5. Réponses: 2
    Dernier message: 28/03/2007, 23h26

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