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 :

SQL-SERVER 2005 - Deux conditions opposées dans une seule et même requête


Sujet :

Développement SQL Server

  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 SQL-SERVER 2005 - Deux conditions opposées dans une seule et même requête
    Bonjour,

    j'ai un 1er code qui me permet de prendre 2 lignes aléatoires dans une table avec une condition de type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT TOP 2
    FROM MA_TABLE
    WHERE COLONNE_1 = 'A'
    ORDER BY NEWID()
    J'ai ensuite un 2ème code qui me fait la meme chose, mais avec la condition
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT TOP 2
    FROM MA_TABLE
    WHERE COLONNE_1 = 'B'
    ORDER BY NEWID()
    Est-il possible de combiner les deux requêtes en une seule (sans complexifier le code ou alourdir les performances) pour qu'il m'affiche 4 lignes, avec :
    - les 2 premières satisfaisant ma première condition, et
    - les 2 dernières, la deuxième condition.

    ?

    (ces résultats seront ensuites exportés vers un fichier Excel)

    Merci d'avance.

  2. #2
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    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
     
       SELECT * 
       FROM(
          SELECT TOP 2 *
          FROM MA_TABLE
          WHERE COLONNE_1 = 'A'
          ORDER BY NEWID()
               ) as T
    UNION
       SELECT * 
       FROM(
          SELECT TOP 2
          FROM MA_TABLE
          WHERE COLONNE_1 = 'B'
          ORDER BY NEWID()
               ) AS T2
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  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
    Je reviens vers vous après avoir tester.
    Merci pour l'idée.

  4. #4
    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
    Merci, ca fonctionne nickel.

    Par contre, j'aimerai aller un peu plus loin.

    Est-il possible que la requête fasse un check sur la deuxieme table (résultats de la deuxième table), et si celle-ci est vide, qu'il me prenne alors 4 lignes aléatoires de ma première table, au lieu de 2.

    Car mon tableau final DOIT contenir 4 lignes !

    Donc:
    soit 2 A et 2 B (dans le meilleur des cas)
    soit 3 A et 1 B (sinon)
    soit 4 A et 0 B (au pire).

    J'espère avoir été assez clair ;-)

  5. #5
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Vous partez donc du principe que seul la requête 2 peux ne pas renvoyer deux enregistrements?
    La première requête renverra toujours 2,3,4 enregistrements?
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  6. #6
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    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
    SELECT TOP 4 * 
    FROM(
    SELECT TOP 2 *,1 as Ordre
    FROM MA_TABLE
    WHERE COLONNE_1 = 'B'
    ORDER BY NEWID()
    ) as T
    UNION
    SELECT * 
    FROM(
    SELECT TOP 4 *,2 as Ordre
    FROM MA_TABLE
    WHERE COLONNE_1 = 'B'
    ORDER BY NEWID()
    ) AS T2
    ORDER BY Ordre
    Principe: votre résultat est trié avec les résultats du B en premier... ainsi la requete ne prendra que maximum deux 'B' et fera le complément avec A pour obtenir 4...
    NB: Je n'accepte pas les bisous :-)
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  7. #7
    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
    Je peux mettre mettre les conditions susceptibles de donner le plus de résultats en amont, effectivement, mais rien ne garantit que la première condition comporte 4 résultats. Je dois avoir au max 4 lignes, et le plus de lignes possibles.

    Je réponds donc OUI à 80%.

    Merci pour votre aide.

  8. #8
    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
    Citation Envoyé par iberserk Voir le message
    SELECT TOP 4 *
    FROM(
    SELECT TOP 2 *,1 as Ordre
    FROM MA_TABLE
    WHERE COLONNE_1 = 'B'
    ORDER BY NEWID()
    ) as T
    UNION
    SELECT *
    FROM(
    SELECT TOP 4 *,2 as Ordre
    FROM MA_TABLE
    WHERE COLONNE_1 = 'B'
    ORDER BY NEWID()
    ) AS T2
    ORDER BY Ordre
    Astucieux, mais etrangement, lorsqu'il existe 2 résulats dans la premiere requête et 4 dans l'autre, mon résultat me donne 6 lignes !! ?

  9. #9
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Citation Envoyé par apnw7931 Voir le message
    Je réponds donc OUI à 80%.
    Je ne suis pas sûr de bien saisir...

    Vous voulez 4 lignes, si l'une ou l'autre des conditions n'est pas vérifiée pour 2 lignes au moins, alors "completer" avec les résultats de l'autre condition ?

    Est-ce que ceci vous donne ce que vous voulez :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT TOP(4) * -- <- spécifiez le nom des colonnes !
    FROM(
        SELECT ROW_NUMBER() OVER (PARTITION BY COLONNE_1 ORDER BY NEWID()) AS RN, * --<-- ici aussi ;)
        FROM MA_TABLE
        WHERE COLONNE_1 = 'A'
        OR COLONNE_1 = 'B'
    ) T 
    ORDER BY RN

  10. #10
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Astucieux, mais etrangement, lorsqu'il existe 2 résulats dans la premiere requête et 4 dans l'autre, mon résultat me donne 6 lignes !! ?
    Avez vous bien pris l’intégralité de la requête y compris le top 4 du haut?
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  11. #11
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Citation Envoyé par apnw7931 Voir le message
    Astucieux, mais etrangement, lorsqu'il existe 2 résulats dans la premiere requête et 4 dans l'autre, mon résultat me donne 6 lignes !! ?
    C'est normal !
    Vous faites le TOP 4 sur le résultat de la première requête (UN TOP 2), puis un UNION avec un autre top 4
    La première partie vous renvoie donc 2 lignes maximum, auxquelles vous ajoutez 4 lignes... cela fait bien 6 lignes

    Pour cette requête, vous devez donc faire le TOP 4 sur le résultat de l'union

  12. #12
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    SELECT TOP(4) * -- <- spécifiez le nom des colonnes !
    FROM(
    SELECT ROW_NUMBER() OVER (PARTITION BY COLONNE_1 ORDER BY NEWID()) AS RN, * --<-- ici aussi
    FROM MA_TABLE
    WHERE COLONNE_1 = 'A'
    OR COLONNE_1 = 'B'
    ) T
    ORDER BY RN
    Je ne suis pas certains que cela fonctionne car si j'ai bien compris (et seulement dans ce cas là...) apnw7931 veux au plus deux valeur de 'B' et compléter par 'A' pour avoir 4 enregistrements?
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  13. #13
    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
    Après un premier test, ca semble correspondre à mon besoin.
    Je vais essayer de faire ca avec 3 conditions maintenant..

    Je reviendrai plus tard avec mes remarques, si besoin.

    Merci encore.

  14. #14
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Quelle solution?
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  15. #15
    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
    Citation Envoyé par iberserk Voir le message
    Je ne suis pas certains que cela fonctionne car si j'ai bien compris (et seulement dans ce cas là...) apnw7931 veux au plus deux valeur de 'B' et compléter par 'A' pour avoir 4 enregistrements?
    Je veux, dans mon exemple, 4 lignes en tout.
    Idéalement, 2 lignes qui satisfait la première condition et 2 lignes satisfaisant la deuxième condition.

    Mais il se peut que l'une des deux conditions ne soit pas respectée (la premiere ou la deuxième). Donc pour être sur d'avoir mes 4 lignes, je veux compenser l'un par l'autre.

    Ainsi, si possible :
    2 A et 2 B
    3 A et 1 B (si seulement 1 B dispo)
    4 A et 0 B (si aucun B dispo)
    1 A et 3 B (si seulement 1 A dispo)
    0 A et 4 B (si aucun A dispo)
    1 A et 1 B (si seulement 1 A et 1 B dispo)
    2 A et 0 B (si seulement 2 1 dispo et aucun B dispo)

    Voyez vous plus clair ??
    Désolé si je me suis mal exprimé..


    La solution de aieeeeeeee semble correspondre (jusqu'a présent)

  16. #16
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Très bien je pensais que nbr da A<2 était impossible...

    Je ne vois pas en quoi la proposition de Aieeeeeeeeeeee( j'ai oublié un e non? ) vous permet de vous assurer d'avoir 2 A et 2 B?

    Aieeeeee une explication?
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  17. #17
    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
    Mon problème se complique avec ceci.
    puisque mes deux requêtes sont en fait :

    CONDITION 1 : COLONNE_1 IN ('A', 'C', 'E')
    CONDITION 2 : COLONNE_1 IN ('B', 'D', 'F')

    Donc ici, j'aimerai 2 lignes satisfaisant la condition 1 ET 2 lignes satisfaisant la condition 2

  18. #18
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Cherchez un peu par vous même...
    Nous vous avons montré les propositions pour une condition donnée... adaptez la conditions en fonction de vos besoin...
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  19. #19
    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
    Citation Envoyé par iberserk Voir le message
    Cherchez un peu par vous même...
    Nous vous avons montré les propositions pour une condition donnée... adaptez la conditions en fonction de vos besoin...

    Oui, d'ailleurs, je n'hésite jamais a chipoter avant de répondre ici.
    Mais avec le code de aieeeuuuuu, que j'ai modifié avec mes conditions, j'ai ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT TOP(4) * -- <- spécifiez le nom des colonnes !
    FROM(
    SELECT ROW_NUMBER() OVER (PARTITION BY COLONNE_1 ORDER BY NEWID()) AS RN, * --<-- ici aussi 
    FROM MA_TABLE
    WHERE COLONNE_1 IN ('A', 'C', 'E') OR COLONNE_1 IN ('B', 'D', 'F')
    ) T 
    ORDER BY RN
    Et du coup, cela ne fonctionne plus correctement du fait que je n'ai plus DEUX valeurs possibles pour ma condition, mais plus. En réalité, comme vous pouvez le voir, ce sont deux groupes de conditions différent.

    Je devrais pouvoir avoir un résultat comme suit :
    A <-- 1ERE CONDITION
    A <-- 1ERE CONDITION
    D <-- 2EME CONDITION
    F <-- 2EME CONDITION

    Autre exemple pratique (hypothèse, pas de B, D et F)
    A <-- 1ERE CONDITION
    A <-- 1ERE CONDITION
    A <-- 1ERE CONDITION
    C <-- 1ERE CONDITION

    et non pas systématiquement moitié/moitié (comme le fait la requête d'aieeeuuuuu)
    A <-- 1ERE CONDITION
    A <-- 1ERE CONDITION
    C <-- 1ERE CONDITION
    C <-- 1ERE CONDITION


    Merci de vous pencher sur mon problème..

  20. #20
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Citation Envoyé par iberserk Voir le message
    Je ne vois pas en quoi la proposition de Aieeeeeeeeeeee( j'ai oublié un e non? ) vous permet de vous assurer d'avoir 2 A et 2 B?

    Aieeeeee une explication?
    Elle ne permet pas d’être sûr d'avoir 2 lignes de chaque...
    elle permet d'avoir un nombre équilibré (par rapport à la valeur de la colonne_1) tant que faire ce peut :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ROW_NUMBER() OVER (PARTITION BY COLONNE_1 ORDER BY ROWID) AS RN
    Je classe sur ROWID distinctement pour chaque valeur de COLONNE_1 :
    La "première" ligne pour COLONNE_1 = 'A' aura RN = 1
    La "deuxième" ligne pour COLONNE_1 = 'A' aura RN = 2
    La "première" ligne pour COLONNE_1 = 'B' aura RN = 1 également

    A la fin, en classant sur RN, on aura en "premier" les "premières" ligne pour chaque valeur de COLONNE_1

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Réponses: 2
    Dernier message: 11/10/2006, 18h43
  2. [Ms SQL server 5.0] gros fichiers dans une table ou sur le DD?
    Par rastamath69 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 10/10/2006, 14h09
  3. [SQL SERVER 2005] Utilisation de Exec dans une fonction ?
    Par Dadou74 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 22/09/2006, 22h09
  4. [SQL server] Comment Fusionner des données dans une requête
    Par MoTUmBo dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 27/07/2005, 15h24
  5. [SQL Server] Passage d'un paramètre dans une procédure
    Par navis84 dans le forum Bases de données
    Réponses: 3
    Dernier message: 14/01/2005, 13h19

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