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 MySQL Discussion :

CONDITION & SQL, afficher le "non existant"


Sujet :

Requêtes MySQL

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2016
    Messages : 14
    Par défaut CONDITION & SQL, afficher le "non existant"
    Salut, je suis en train de bosser sur une bdd et je bloque un peu. Je veux eviter de créer de nouvelle table ou de modifier la base en elle meme.

    Mon but afficher "partie intérrompue" dans CASE si la colonne label ne possède pas de fin de partie.
    Si elle en possède une on vérifie alors la colone intitule et on retourne dans case ce qui correspond

    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 partie,label, 
    CASE
    	WHEN EXISTS( SELECT label 
    			FROM enregistrement 
    			WHERE label LIKE 'fin-partie') THEN (
    			CASE
    			WHEN intitule='echec' THEN 'Perdue'
    			WHEN intitule='reussite' THEN 'Réussie'
    			END)
    	ELSE 'Partie interrompue'
    END AS Résultat
    FROM enregistrement
    WHERE partie LIKE '447'

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 954
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 954
    Par défaut
    Pas besoin de refaire un SELECT :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT partie,label, 
           CASE WHEN label = 'fin-partie' 
                THEN CASE WHEN intitule='echec'    THEN 'Perdue'
                          WHEN intitule='reussite' THEN 'Réussie'
    		          END
    	        ELSE 'Partie interrompue'
            END AS Résultat
      FROM enregistrement
     WHERE partie = '447'

  3. #3
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 636
    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 636
    Billets dans le blog
    10
    Par défaut
    De plus
    - faire un like sans le symbole % ne fonctionnera pas (ligne 6 de votre requête)
    - tester des chaines de caractères est dangereux : erreurs de saisie, majuscules/minuscules, accents... tester un code est préférable

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2016
    Messages : 14
    Par défaut
    Merci pour les conseils (j'ai pas mal abusé des like je vais modifier ça dans les autres requêtes que j'ai fais)

    Mais, mon soucis c'est que j'ai des parties qui n'ont pas le label 'fin-partie' qui me permet de savoir quand elles sont perdue ou gagnée (dans ce cas elles doivent etre considérées comme interrompue)

    Mais je ne voudrais retourné un résultat à une ligne avec partie, label(facultatif c'est plus pour voir si ça marche), et resultat. Résultat qui est donc "gagnée" ou "perdue" si le label 'fin-partie' existe et doit être 'interrompue' sinon. Y a til possibilité de faire juste un affichage avec une ligne créer juste pour l'affichage (temporaire non ajoutée au tableau) ou le label serait marqué null et non d'avoir le résultat 'interrompue' sur tout les labels différents de 'fin-partie'

  5. #5
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Par défaut
    Bonjour,

    Citation Envoyé par escartefigue Voir le message
    - faire un like sans le symbole % ne fonctionnera pas (ligne 6 de votre requête)
    Si ça fonctionne, mais il y a de différence avec l'utilisation de l'opérateur =

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select 'a' = 'a'; -- 1
    select 'a ' = 'a'; -- 1
    select 'a' like 'a'; -- 1
    select 'a ' like 'a'; -- 0
    select 'a_' = 'a\_'; -- 0
    select 'a_' like 'a\_'; -- 1

    A+.

  6. #6
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 636
    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 636
    Billets dans le blog
    10
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Bonjour,
    Si ça fonctionne, mais il y a de différence avec l'utilisation de l'opérateur =
    Non : fonctionner signifie "exercer sa fonction, produire le résultat attendu", or, l'utilisation de like sans wildcard ne permet pas d'obtenir le résultat attendu

    cf. http://www.cnrtl.fr/definition/fonctionner
    ou encore https://www.larousse.fr/dictionnaire...ctionner#34416

  7. #7
    Membre prolifique Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 917
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 917
    Par défaut
    Salut bastien81.

    Quelques remarques :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE label LIKE 'fin-partie'
    1) la bonne écriture est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE label = 'fin-partie'
    Comme dit Escartefigue, le like s'utilise avec '%'.
    De plus, il y a des différences de comportement entre le '=' et le 'like' et donc, les deux opérateurs ne sont pas équivalents.

    D'autre part, vous n'êtes pas obligé de mettre un libelle, mais vous pouvez utiliser une codification.
    par exemple :
    --> 0 : partie non terminée.
    --> 1 : partie terminée mais gagnée.
    --> 2 : partie terminée mais perdue.

    2) pour les valeurs numériques, vous devez mettre le type "integer unsigned" et non "varchar()".
    De ce fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE  partie like '447'
    devient :
    3) j'ai tenté de répondre à votre dernier message.
    Vous devez distinguer les différentes valeurs de "label" ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    select  partie,
            label,
            case when label = 'fin-partie' then case intitule when     'echec' then 'Perdue'
                                                              when 'resussite' then 'Réussie'
                                                                               else 'Autre 1'
                                                end
                 when label is null        then 'Partie interropue'
                                           else 'Autre 2'
            end as resultat
     
      FROM  enregistrement
     WHERE  partie = '447'
    La valeur "autre 1" vous donnera un renseignement sur le fait qu'une partie est terminée, mais elle est peut-être à 'partie nulle'.
    La valeur "autre 2" vous donnera une valeur autre que null ou 'fin-partie' dans la colonne "label".

    @+

  8. #8
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2016
    Messages : 14
    Par défaut
    Merci pour vos réponses ça m'avait bien aidé . Depuis mon projet avance petit à petit, je me permet une question connaissez vous un site/logiciel qui simplifie les requetes si possible car j'en ai une assez importante de "7 lignes" que je veux modifier

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

Discussions similaires

  1. [2008R2] Utilisation d'une DMV non existant sur une version sql
    Par Boubou2020 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 26/05/2015, 15h14
  2. Afficher valeur ou non sous conditions
    Par sand111510 dans le forum Modélisation
    Réponses: 1
    Dernier message: 12/09/2012, 16h48
  3. SQL afficher une variable que si elle existe ?
    Par humberto dans le forum Langage SQL
    Réponses: 1
    Dernier message: 31/01/2010, 00h15
  4. [SQL] Afficher oui ou non quand on confirme une personne.
    Par snakejl dans le forum PHP & Base de données
    Réponses: 50
    Dernier message: 29/06/2006, 12h24
  5. Réponses: 9
    Dernier message: 17/03/2005, 09h20

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