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 :

Forger une requete de recherche sur plusieurs tables.


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Inscrit en
    Janvier 2008
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 29
    Points : 17
    Points
    17
    Par défaut Forger une requete de recherche sur plusieurs tables.
    Bonjour,
    J’ai une BDD contenant plusieurs tables dont : chercheur, publication, projet, équipe …

    Un chercheur appartient à une seule équipe.
    Un ou plusieurs chercheurs publient une ou plusieurs publications.
    Un ou plusieurs chercheurs participent à un ou plusieurs projets de recherche.
    Une équipe chapote un ou plusieurs projets.

    Donc j’ai les 6 tables suivant :

    Chercheur ( id, id_equipe, est_chef, attributs de chercheur )
    Equipe ( id, attributs de equipe )
    Publication ( id, attributs de publication )
    Publication_chercheur ( id_publication, id_chercheur )
    Projet ( id, id_equipe, id_chef_projet, id_equipe, attributs de projet )
    Projet_chercheur ( id_projet, id_chercheur )

    Je voudrai avec ça faire un truc qui permet à l’utilisateur de formuler une requête de recherche dynamiquement selon ce qu’il veut chercher.
    Genre j’ai pour chaque entité, chercheur, équipe, publi, projet :
    [ liste déroulante pour choisir l’attribut ] [ liste déroulante pour choisir = ou != ] [ input pour saisir une valeur ]
    ( je vais noté ce formulaire par {chercheur} par exemple ).

    Don pour permettre de faire la recherche sur plusieurs vue de mes tables, je fais –en théorie- un formulaire du genre :
    {chercheur} [et/ou] {équipe} [et/ou] [chercheur appartient ou pas à équipe] [et/ou] {publication} [et/ou] [chercheur a publié ou pas la(les) publication(s)] [et/ou] {projet} [et/ou] [equipe chapote ou pas le(s) projet(s)] [et/ou] [chercheur participe à projet].

    Mais je ne vois vraiment pas comment je vais formuler (forgé) ma requête de recherche.
    Avez-vous des idées ?

    Merci beaucoup

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    47
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2007
    Messages : 47
    Points : 58
    Points
    58
    Par défaut
    Une 1ère piste:

    Si tu veux que le nom de tes objets puisse être variable (comme le nom de la table), tu devras utiliser du SQL dynamique.

    http://sheikyerbouti.developpez.com/execute_immediate/

  3. #3
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut !

    Tu vois la tête de ta requête "de base" ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT *
    FROM T1, T2, T3, ...
    WHERE
       Jointures
     AND Filtres
    "Jointures", c'est ce qui fait le lien logique entre tes tables.
    Chercher.IdEquipe = Equipe.IdEquipe, ...

    Quand tu génères ta requête à partir des valeurs des listes déroulantes, c'est le filtre que tu touches.

    Par exemple, tu pourrais restreindre le résultat sur le chercheur X, ou ne pas restreindre sur ce critère.
    Dans un cas, tu rajoute AND NomCherCheur = 'X', dans l'autre non...

    => Le côté dynamique, c'est toi qui le gère en fonction des valeurs des listes.

    Ensuite, pour bien faire, il faut aussi que tes listes se mettent à jour dynamiquement en fonction des autres listes.
    Par exemple, lorsque l'utilisateur choisit une certaine équipe, tu alimentes la liste Chercheur avec les chercheurs de cette équipe, ...

    Bon courage !

  4. #4
    Membre à l'essai
    Inscrit en
    Janvier 2008
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 29
    Points : 17
    Points
    17
    Par défaut
    Tout d'abord, merci pour vos réponses

    Citation Envoyé par pacmann Voir le message
    => Le côté dynamique, c'est toi qui le gère en fonction des valeurs des listes.
    Pour Equipe par exemple; Les valeurs qu'on choisi dans la liste déroulante ne sont pas les équipes listé, se sont plutôt les attributs de équipe (par rapport au quel on peut effectué une recherche).

    D'ailleurs mon idée de liste déroulante pour choisir l'attribut auquel on veux chercher est un peut à l'arrache, car je ne pourrai pas exprimé le fait qu'on puisse faire une recherche par rapport à plusieurs attributs de l'objet (équipe par exemple).

    Citation Envoyé par pacmann Voir le message
    Ensuite, pour bien faire, il faut aussi que tes listes se mettent à jour dynamiquement en fonction des autres listes.
    Par exemple, lorsque l'utilisateur choisit une certaine équipe, tu alimentes la liste Chercheur avec les chercheurs de cette équipe, ...
    Vous voulez parlé de la liste des attributs ? ou ... ?
    La requête complète n'est pas encore forgé et effectué pour connaitre les chercheurs appartenant à cette équipe, et il faudrai exprimé ça dans la requête elle même avec la jointure equipe.id = chercheur.id_equipe.

    Et le problème principale aussi c'est que normalement mes jointures seront exprimé selon ce qu'on a utilisé comme entité pour la recherche, càd:

    Si {equipe} Et {chercheur} Alors Prendre en considération que chercheur "appatient ou pas" à equipe. ==> equipe.id = chercheur.id_equipe (ou bien equipe.id <> chercheur.id_equipe)

    Si {chercheur} Et {projet} Alors prendre en considération que chercheur(s) participe à projet(s).

    Si {equipe} Et {projet} Alors prendre en considération que equipe chapote projet(s).

    Si {chercheur} Et {publication} Alors prendre en considération que chercheur(s) est un auteur (ou pas) de publication(s).

    Vous voyez les problèmes ?

Discussions similaires

  1. [1.x] Comment faire une recherche sur plusieurs tables
    Par farhaenis dans le forum Symfony
    Réponses: 6
    Dernier message: 01/07/2011, 17h47
  2. Recherche sur plusieurs tables en même temps
    Par Zouzou1er dans le forum VBA Access
    Réponses: 5
    Dernier message: 09/10/2007, 09h40
  3. Recherche sur plusieurs tables
    Par micatmidog dans le forum Langage SQL
    Réponses: 2
    Dernier message: 09/06/2007, 16h28
  4. [MySQL] moteur de recherche sur plusieurs tables
    Par harlock59 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 10/04/2007, 15h23
  5. [MySQL] Recherche sur plusieurs tables
    Par hubidev dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 21/03/2006, 10h42

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