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 :

Besoin d'aide sur une requête avec jointure


Sujet :

Langage SQL

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mars 2023
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Mars 2023
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Besoin d'aide sur une requête avec jointure
    Bonjour,

    J'ai deux tables dans une base Mysql.
    La première s'appelle Call et contient l'ensemble des appels téléphoniques passés par des contacts.
    La seconde s'appelle donc Contact et contient ces contacts.
    La table Call contient le champ contact_id, lié au champ ID de la table contact.
    Et un contact peut avoir passé plusieurs coups de téléphone, donc plus enregistrements call par contact. De même, un contact peut n'avoir passé aucun coup de téléphone, donc aucun enregistrement relatif dans la table call.

    Dans ma table call, j'ai un champ qui indique la date du coup de téléphone (created_at).
    Enfin, dans la table des contacts, j'ai la date de création du contact (created_at).

    Je souhaiterais sélectionner l'ensemble des contacts créés il y a plus de deux ans et dont aucun appel n'a été passé ces 6 derniers mois. (Si 1 seul appel a été passé il y a moins de 6 mois, je ne le sélectionne pas)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT *  from contact inner join call where DATE(contact.created_at)<='2021-03-15' AND DATE(call.created_at)<='2022-09-15'
    Mais cela me sort l'ensemble des contacts.

    Je suis conscient que cela ne doit pas être compliqué à mettre en place, mais j'ai beau le tourner dans tous les sens, je n'arrive pas au résultat escompté.
    Pourriez-vous m'aiguiller ?
    Merci d'avance.

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    Ta requête renvoie les clients créés avant le 15 mars 2012, et qui ont passé un appel avant le 15 septembre 2022.

    Pour ce que tu veux faire il faut sélectionne les clients créés avant le 15 mars, mais pour lesquels il n'y a pas de ligne dans la table call dont la date est postérieure au 15 septembre.
    Tu as plusieurs solutions: NOT EXISTS, LEFT JOIN...
    Exemple:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select contact.*
    from contact
    left outer join call on call.id_contact = contact.id and call.created_at > '2022-09-15'
    where call.id is null

    Tatayo.

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mars 2023
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Mars 2023
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci beaucoup de ton aide.
    Effectivement, cela fonctionne.
    Et comme on dit souvent dans ces cas-là, c'était évident ! Mais je butais depuis un moment et grâce à toi, je vais avancer.
    Merci encore

Discussions similaires

  1. Aide sur une requête avec jointure et LIMIT 1
    Par mister3957 dans le forum Langage SQL
    Réponses: 7
    Dernier message: 28/06/2013, 20h17
  2. Besoin d'aide sur une requête avec un MAX()
    Par lcristin dans le forum Langage SQL
    Réponses: 5
    Dernier message: 05/03/2013, 14h57
  3. Besoin aide sur une requête avec jointure
    Par PoichOU dans le forum Requêtes
    Réponses: 3
    Dernier message: 31/08/2010, 18h32
  4. Aide sur une requête avec jointure..
    Par WeDgEMasTeR dans le forum Requêtes
    Réponses: 7
    Dernier message: 10/11/2009, 18h09
  5. Besoin d'aide sur une requete avec jointure et MAX()
    Par droog dans le forum Requêtes
    Réponses: 4
    Dernier message: 04/07/2007, 18h23

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