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

Décisions SGBD Discussion :

Architecture BDD et recherche d'éléments


Sujet :

Décisions SGBD

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    551
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2005
    Messages : 551
    Par défaut Architecture BDD et recherche d'éléments
    Bonjour,

    J'ai une base de données qui stocke les données pour un site immobilier en ligne.
    La table à laquelle s'articule les autres éléments est donc la table BIEN.

    Lors de la recherche, il faut afficher :
    - une photo qui se trouve dans la table PHOTO
    - quelques renseignements se trouvant dans la table BIEN
    - le code postal qui se trouve dans la table LOCALITE

    Architecture de la bdd :
    (bien.fkappartement,immeuble.idAppartement / immeuble.fkLOcalite Localite.idLOcalite / localite.codepostal).
    (photo.fkbien,bien.idbien)

    Je pensais recopier le codepostal et le nom de la photo principale à afficher lors de la recherche dans la table BIEN et gérer tous changements de ces éléments grâce à des triggers qui répercuteraient la/les modifications de, par exemple, la photo principale dans la table bien.

    Que pensez-vous de cette façon de faire ? C'est pourri ou pas ?
    Le but est d'éviter d'avoir des requêtes interminables et je me dis qu'ainsi au niveau performances c'est plus rapide et moins compliqué

    merci d'avance

    Nath

  2. #2
    Expert confirmé
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 197
    Billets dans le blog
    1
    Par défaut
    Vous voulez dénormaliser, c'est ça ?

    En quel honneur ?

    Une simple vue suffit à récupérer ces informations sans problème...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    create view v_rechweb
    as
    select b.champ1, b.champ2, ..., p.image, l.codepostal
    from bien b
    inner join immeuble i on i.idappartement = b.fkappartement
    inner join localite l on l.idlocalite = i.fklocalite
    inner join photo p on p.fkbien = b.idbien and p.numero = 1
    Il faut trouver un critère pour ne prendre qu'une photo par bien.
    J'ai donc "inventé" un champ "numero" qui est le numéro de la photo du bien, et j'y ai appliqué le filtre " = 1" pour ne prendre toujours que la première photo.

    Voyez ce que vous pouvez utiliser dans votre base pour faire la même chose.

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    551
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2005
    Messages : 551
    Par défaut
    OUi je veux ou voulais dénormaliser

    Je n'ai pas pensé à la vue, merci !
    J'ai un peu oublié mes cours.....

  4. #4
    Expert confirmé
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 197
    Billets dans le blog
    1
    Par défaut
    Une règle d'or : NE JAMAIS DENORMALISER

    Après, au cas par cas, il peut arriver que peut-être, une petite dénormalisation par ci ou par là puisse être pertinente, mais clairement pas dans ce genre de situation.

    Un exemple classique de dénormalisation par exemple, c'est de stocker un champ calculé, lorsque l'algo qui permet d'obtenir la valeur est particulièrement complexe. Par exemple, sur une facture, lorsque tous les produits ne sont pas soumis aux mêmes taxes, qu'il y a des frais de dédouanement, de transport, etc.

    Mais clairement pas pour éviter des jointures simples

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    551
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2005
    Messages : 551
    Par défaut
    merci pour le complément d'inforamtions !

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

Discussions similaires

  1. [HF9] Architecture BDD Hyperfile développée
    Par moabomotal dans le forum HyperFileSQL
    Réponses: 5
    Dernier message: 03/06/2006, 12h24
  2. [Architecture] BDD et poste client
    Par maminova77 dans le forum Général Java
    Réponses: 2
    Dernier message: 05/03/2006, 19h28
  3. formulaire ASP bdd access recherche
    Par ghita269 dans le forum ASP
    Réponses: 8
    Dernier message: 20/11/2005, 00h57
  4. [SET]Recherche d'éléments communs à 2 sets
    Par CappCorp dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 03/01/2005, 18h03
  5. [JDOM] Recherche d'éléments en JDOM
    Par newfsch dans le forum Format d'échange (XML, JSON...)
    Réponses: 2
    Dernier message: 09/04/2004, 19h33

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