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

 MySQL Discussion :

Construction de tables relationnelles simples


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 227
    Par défaut Construction de tables relationnelles simples
    Bonjour à tous,

    Je réalise un projet internet comportant une BDD assez simple puisque ne contenant qu'une table...

    Je vais y rajouter une 2 ème table et donc la lier à la premiere.
    Je mets donc le pied dans un univers que je ne connais pas (je ne suis pas informaticien): Les bases relationnelles.
    J'ai un peu potassé le sujet mais cela reste assez flou pour moi et les exemples ne m'ouvre pas trop l'esprit sur ce que je veux faire.

    J'ai une table contenant le champs "catégorie".
    Parmis ces catégories, j'ai l'enregistrement "hotel".

    J'aimerais quand s'affiche le nom d'un hôtel que l'on voit quelques options le concernant.
    Exemple:
    "Hotel Wesminster" options: "Piscine", "Animeaux acceptés", "Télévision" etc...

    C'est pour ces options que je pense rajouter une 2 ème table.

    Mais je ne visualise pas trop comment faire.

    Table Options_hotels contenant:
    Id Auto incrémenté INT(11)
    Options Varchar 255

    Puis ensuite je mets comme enregistrements dans le champs Options:
    1 - Climatisation
    2 - Animeaux acceptés
    3 - Télévision

    C'est ça?

    Pardon pour la naiveté de ma question mais c'est la première fois que je fais une base relationnelle...

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 063
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 063
    Par défaut
    Bonjour,

    Le cas de figure que tu décris va nécessiter 3 tables.
    En effet, tu es face à une relation N-N : un hôtel peut avoir plusieurs options et une option peut se retrouver dans plusieurs hôtels.

    Ça se modélise donc en 3 tables :
    1- table hôtel : id_hotel, nom_hotel, nb_chambres...
    2- table options : id_option, nom_option...
    3- table hôtel_option : id_hotel, id_option (contient 1 ligne par option et par hôtel).

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 227
    Par défaut
    Citation Envoyé par ced Voir le message
    Bonjour,

    Le cas de figure que tu décris va nécessiter 3 tables.
    En effet, tu es face à une relation N-N : un hôtel peut avoir plusieurs options et une option peut se retrouver dans plusieurs hôtels.

    Ça se modélise donc en 3 tables :
    1- table hôtel : id_hotel, nom_hotel, nb_chambres...
    2- table options : id_option, nom_option...
    3- table hôtel_option : id_hotel, id_option (contient 1 ligne par option et par hôtel).

    ced
    Bonjour Ced,
    Merci pour la réponse.

    J'ai mal exposé la situation, désolé.
    J'ai une table "Société".
    Id_société
    nom_société
    catégorie_société (parmi lesquelles la catégorie "Hôtels". Ces catégories sont renseignées à chaque fois vu que je n'ai pas de table "Catégories"...)

    Partons du principe que je laisse cette table en place et verrai plus tard pour la scinder afin de ne pas trop complexifier mon exemple au début...

    Dans ce cas, il me reste à créer si j'ai bien compris la table "options" et la table "hotel_option".

    Ce que j'ai du mal à visualiser, c'est où sera saisie la série des options...
    tu dis:
    "table hôtel_option : id_hotel, id_option (contient 1 ligne par option et par hôtel)"

    Cela veut il aussi dire autant de lignes que d'options pour 1 hôtel du genre:
    id_hotel "Wesminter" id_option "Climatisation"
    puis
    id_hotel "Westminster" id_option "Piscine"
    etc...?
    C'est cela?

    Ton avatar c'est Aikido ou zazen?

  4. #4
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    Un petit tour dans les tuto Merise me semble indispensable...
    http://sqlpro.developpez.com/cours/modelisation/merise/
    http://www.sam-mag.com/P53,53,5,43,,,default.aspx
    http://www.compucycles.com/nouveausi...Article_07.htm

    Pour repartir de ton cas...
    J'ai une table "Société".
    Id_société
    nom_société
    catégorie_société (parmi lesquelles la catégorie "Hôtels". Ces catégories sont renseignées à chaque fois vu que je n'ai pas de table "Catégories"...)
    Règle de gestion :
    "Une société est d'une certaine catégorie et une catégorie peut englober plusieurs sociétés."

    MCD :
    Categorie -0,n----Englober----1,1- Société

    Tables :
    Categories (C_Id, C_NomCategorie, ...)
    Societes (S_Id, S_RaisonSociale, S_IdCategorie, ...)

    La clé primaire est souligné et la clé étrangère est en italique.

    Exemple de requête :
    Quelles sont toutes les sociétés de catégorie "Hôtel" ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT s.S_ID, s.S_RaisonSociale
    FROM Societes s
    INNER JOIN Categories c ON s.S_IdCategorie = c.C_Id
    WHERE c.C_NomCategorie = "Hôtel"
    Applique ce principe à toute ta base et elle sera correctement conçue et solide.

    Continuons avec les options...

    Règle de gestion :
    "Un 'Hôtel' peut proposer des options et une option peut être proposée par plusieurs hôtels."

    MCD : (en se servant des tables déjà créées)
    Société -0,n----Proposer----0,n- Option

    Tables :
    Options (O_Id, O_LibelleOption, ...)
    Proposer (P_IdHotel, P_IdOption, ...)

    Exemple de requête :
    Quelles sont les options proposées par l'hôtel "Westminster" ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT o.LibelleOption
    FROM Options o
    INNER JOIN Proposer p ON o.O_Id = p.P_IdOption
      INNER JOIN Societes s ON p.P_IdHotel = s.S_Id
    WHERE s.S_RaisonSociale = "Westminster"
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  5. #5
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 063
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 063
    Par défaut
    Effectivement, j'ai limité mon exemple à une table Hotel, parce que je n'avais pas le schéma de la table société.
    Mais ça revient au même, sauf que tu mets des options à des sociétés (qui peuvent être des hôtels ou autres, si ça a un sens pour les autres catégories de société).

    Il te faudra donc une table de passage "societe_option" 2 colonnes : id_societe et id_option.

    Pour le stockage (plutôt que la saisie) des options, tu as bien compris comment ça fonctionne : dans la table de passage, il y a une ligne par société ET par option. C'est comme ça qu'on modélise et qu'on stocke les relations N-N.

    Je te recommande la lecture de ce tutoriel. Ca te permettra sûrement d'y voir un peu plus clair.

    Bon courage,

    ced

    PS : mon avatar, c'est aïkido (même si zazen va avec ).
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

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

Discussions similaires

  1. Aide requete Join + table relationnelle
    Par yann5559 dans le forum Requêtes
    Réponses: 5
    Dernier message: 31/07/2008, 15h13
  2. Réponses: 6
    Dernier message: 19/05/2007, 13h34
  3. retrouvé le schema d'une table relationnel
    Par gaussprodada dans le forum Administration
    Réponses: 1
    Dernier message: 23/01/2007, 10h41
  4. [Hibernate] Hibernate DB de 200 Table relationnelle
    Par servlet1 dans le forum Hibernate
    Réponses: 3
    Dernier message: 11/03/2006, 18h27
  5. Insertion dans une table relationnelle
    Par etiennegaloup dans le forum Langage SQL
    Réponses: 22
    Dernier message: 01/11/2005, 17h39

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