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

Langage SQL Discussion :

[T-SQL] Amélioration requête


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Par défaut [T-SQL] Amélioration requête
    Bonjour,

    j'ai la requête suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
     
    DECLARE @der_x int, @der_y int, @der_z int
    SELECT @der_x = 1
     
    SELECT @d_pos_x=a.pos_x,
           @d_pos_y=a.pos_y,
           @bat=bat
    FROM table1 a inner join table2 b on a.id = b.id
    WHERE b.pos_x=ISNULL(@der_x,-99999999)
      AND b.pos_y=ISNULL(@der_y,-99999999)
      AND b.pos_z=ISNULL(@der_z,-99999999)
     
    IF @@ROWCOUNT=0
    BEGIN
        SELECT @d_pos_x=a.pos_x,
               @d_pos_y=a.pos_y,
               @bat=bat
        FROM table1 a inner join table2 b on a.id = b.id
        WHERE b.pos_x=ISNULL(@der_x,-99999999)
          AND b.pos_y=ISNULL(@der_y,-99999999)
     
        IF @@ROWCOUNT=0
        BEGIN
            SELECT @d_pos_x=a.pos_x,
                   @d_pos_y=a.pos_y,
                   @bat=bat
            FROM table1 a inner join table2 b on a.id = b.id
            WHERE b.pos_x=ISNULL(@der_x,-99999999)
        END
    END
    Y a t-il une meilleure solution d'écriture ?
    C'est fonctionnel certes, mais niveau lisibilité ...

    Le SGBD utilisé est Sybase.

    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Tu as raison sur le niveau lisibilité parce que, au niveau fonctionnel, c'est sensé faire quoi ?
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Par défaut
    Affecter aux variables @d_pos_x, @d_pos_y, @bat la première occurrence trouvée en fonction de la position x, y, z

    Si x,y,z sont renseignés et existent dans table2 on prend les valeurs trouvées.
    Sinon on se contente de regarder en x, y...
    Sinon on se contente de regarder en x...

    Je sais pas si c'est bien clair
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  4. #4
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Par défaut
    Pour faire plus simple, ça reviendrait à écrire une chose de la sorte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    SELECT *
    FROM table1
    WHERE x = 1 AND y = 2 AND z = 3
     
    -- -> Si aucun resultat, alors :
    SELECT *
    FROM table1
    WHERE x = 1 AND y = 2
     
    -- -> Si aucun resultat, alors :
    SELECT *
    FROM table1
    WHERE x = 1
    D'ou ma question...
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Dit comme ça .... c'est presque déjà écrit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
        SELECT  *
        FROM    table1
        WHERE   x = 1
            AND y = 2 
            AND z = 3
    UNION 
        SELECT  *
        FROM    table1
        WHERE   x = 1
            AND y = 2
            AND NOT EXISTS
                (   SELECT  1
                    FROM    table1
                    WHERE   x = 1
                        AND y = 2 
                        AND z = 3
                )       
    UNION 
        SELECT  *
        FROM    table1
        WHERE   x = 1
            AND NOT EXISTS
                (   SELECT  1
                    FROM    table1
                    WHERE   x = 1
                        AND y = 2
                )
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  6. #6
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Par défaut
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

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

Discussions similaires

  1. Améliorer requête SQL beaucoup trop longue
    Par faulk dans le forum Langage SQL
    Réponses: 4
    Dernier message: 05/06/2014, 12h12
  2. Amélioration requête SQL
    Par nounours21_6 dans le forum Langage SQL
    Réponses: 14
    Dernier message: 20/06/2007, 07h37
  3. amélioration requête sql
    Par mmb04 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 17/04/2007, 10h47
  4. [SQL Server]Requête avec DateDiff
    Par sangokus dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 10/05/2004, 14h44
  5. [SQL] Ma requête m'oblige à saisir des valeurs manuellement
    Par bossun dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 22/10/2003, 13h29

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