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

PHP & Base de données Discussion :

signalement d'une jonction non abouti [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut signalement d'une jonction non abouti
    Bonsoir,

    Est-il possible sur une requête (mysql) dans une jonction qui n'abouti pas de mettre un marqueur quelque part qui permette ensuite à la lecture du résultat de la requête que l'enregistrement n'existe pas.

    Voici ma requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM `t_users` LEFT OUTER JOIN t_users_droits ON t_users_droits.id_user=t_users.id_user WHERE t_users.id_trt>0 and t_users.id_trt<5
    Si "t_users_droits" ne renvoi pas d'enregistrement, j'ai besoin de le savoir pour le traitement suivant.

    Merci d'avance

  2. #2
    Membre émérite Avatar de fallais
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juillet 2006
    Messages
    858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Juillet 2006
    Messages : 858
    Par défaut
    Tu mets un if dans ta requete

  3. #3
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut
    C'est à dire faire quelque chose du style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT * FROM `t_users` 
    LEFT OUTER JOIN t_users_droits 
    ON t_users_droits.id_user=t_users.id_user WHERE
    AND (ISNULL(t_users_droits.id_user)
        Et comment j'influence la requete résultante ?
    )
    AND t_users.id_trt BETWEEN 1 AND 4
    La question est dans ma requête

  4. #4
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut
    J'ai ceci et ça fonctionne très bien



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT ISNULL(t_users_droits.id_user) as user_droit_existe FROM `t_users` 
    LEFT OUTER JOIN t_users_droits 
    ON t_users_droits.id_user=t_users.id_user WHERE
    t_users.id_trt BETWEEN 1 AND 4
    "user_droit existe" prend la valeur est un booléen qui prend la valeur 1 sir l'enregistrement de la table jointe n'existe pas.

    Ensuite dans mon script, je test la valeur de "user_droit_existe"

    Merci pour l'aiguillage.

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

Discussions similaires

  1. Recherche dans une liste non trié
    Par Oberown dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 13/09/2004, 13h56
  2. [Regex] reconnaitre une chaîne non complète
    Par EdoBvD dans le forum Collection et Stream
    Réponses: 19
    Dernier message: 13/07/2004, 17h14
  3. Réponses: 4
    Dernier message: 13/06/2004, 15h28
  4. Capture d'une form non visible
    Par Linkin dans le forum Composants VCL
    Réponses: 3
    Dernier message: 14/04/2004, 14h58

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