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écisions SGBD Discussion :

optimisation requetes avec base de données


Sujet :

Décisions SGBD

  1. #1
    Membre averti Avatar de flogreg
    Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 432
    Points : 392
    Points
    392
    Par défaut optimisation requetes avec base de données
    Bonjour à tous.

    Quand j'ai appris à developper, dans mes programmes, je faisais une requete du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select * from matable where monchamps1=13 order by monchamps2
    Si au lieu de faire ca, (je prends l'exemple d'Access 2000) je crée une requete dans ma base comme ca:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select * from matable where monchamps1=13 order by monchamps2
    puis dans mon code je fais:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select * from marequete
    Est ce que ca va etre plus rapide? Est ce ca que l'on appele procédure stockée?

    Merci de vos réponses. C'est vrai que je n'ai jamais développé d'application sur PC avec de grosses base de données. Avant je n'utilisais que du RPG sur AS400 et on utilisait des fichiers logiques

  2. #2
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 911
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 911
    Points : 6 032
    Points
    6 032
    Par défaut
    Oui, tu as raison, en gros.

    Seul bémol, il faut que ton SGBD supporte le passage de tableau en retour de ta PS.

  3. #3
    Membre averti Avatar de flogreg
    Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 432
    Points : 392
    Points
    392
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Seul bémol, il faut que ton SGBD supporte le passage de tableau en retour de ta PS.
    Je n'en ai aucune idée. De toute facon, ca ne sera surement pas Access 2000 mais plutot Sql Server ou Interbase. Mais sinon c'est ca une procédure stockée ou pas?

  4. #4
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 911
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 911
    Points : 6 032
    Points
    6 032
    Par défaut
    Oui, c'est bien cela une procédure stockée.

  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 862
    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 862
    Points : 53 009
    Points
    53 009
    Billets dans le blog
    6
    Par défaut
    Cela n'est absolument pas une procédure stockée. De plus des requêtes avec SELECT * sont totalement contre peformantes.

    A lire sur le sujet : http://sqlpro.developpez.com/cours/optimiser/

    A +

  6. #6
    Membre averti Avatar de flogreg
    Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 432
    Points : 392
    Points
    392
    Par défaut
    oui je savais pour le select *. Ce n'était que pour l'exemple.

    Par contre le lien est très instructif, je le recommande. J'y ai appris plein de chose. Je crois que je vais aller faire un petit tour du coté des tutoriels SQL . Beaucoup de chose que je ne savais pas!

    Par contre quelqu'un pourrait m'expliquer ce qu'est une procédure stockée?

  7. #7
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    une procédure stockée est un programme sauvegardé dans la base de données

    Et je vois mal comment en ajoutant une étape tu pourrais être plus performant

  8. #8
    Membre averti Avatar de flogreg
    Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 432
    Points : 392
    Points
    392
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Et je vois mal comment en ajoutant une étape tu pourrais être plus performant
    Alors que doi je faire? Lancer une requete complexe depuis mon programme? Créer une view dans ma base puis faire une petite requete dessus dans mon programme? Apprendre les procédures stockée?
    Je viens de relire la page pour optimiser le SQL et SGBDR. Il recommande de créer des vues pour les requetes

  9. #9
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    A mon avis la solution dépend :

    - Du SGBD
    - Du langage de programmation

    En php par exemple c'est beaucoup moins contraignant de passer par une vue alors que dans Powerbuilder on pourra passer sans problème par la requête. Ensuite, la gestion des vues dépends probablement du SGBD mais là je peux me tromper.

    Enfin, en effet la vue ne peut pas faire de mal mais en aucun cas elle améliore les performances... du moins pas dans tous les SGBD

  10. #10
    Membre averti Avatar de flogreg
    Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 432
    Points : 392
    Points
    392
    Par défaut
    Merci d'avoir pu me renseigner. Je pense que pour moi le temps est venu d'améliorer mes compétences en SQL. Je pense que c'est déjà la première des choses quand on veut optimiser une base de données.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 30/04/2008, 08h58
  2. Réponses: 2
    Dernier message: 10/11/2005, 16h59
  3. InstallShield avec base de données
    Par duga dans le forum C++Builder
    Réponses: 8
    Dernier message: 18/03/2005, 15h44
  4. CD ROm avec base de données
    Par marcoco dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 10/02/2005, 14h16
  5. requête SQL avec paramètre en vb avec base de donnée SQL srv
    Par dialydany dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 01/02/2005, 10h33

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