Précédent   Forum des professionnels en informatique > Bases de données > Décisions SGBD
Décisions SGBD Forum de décisions sur le choix en bases de données. Le Comparatif
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 08/11/2011, 10h12   #1
Membre actif
 
Inscription : novembre 2005
Messages : 537
Détails du profil
Informations forums :
Inscription : novembre 2005
Messages : 537
Points : 198
Points : 198
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
nath-0-0 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/11/2011, 10h21   #2
Membre Expert
 
Homme Sylvain Devidal
Chef de projets Générix
Inscription : février 2010
Messages : 1 062
Détails du profil
Informations personnelles :
Nom : Homme Sylvain Devidal
Âge : 33
Localisation : France, Rhône (Rhône Alpes)

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

Informations forums :
Inscription : février 2010
Messages : 1 062
Points : 1 515
Points : 1 515
Vous voulez dénormaliser, c'est ça ?

En quel honneur ?

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

Code :
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.
StringBuilder est déconnecté   Envoyer un message privé Réponse avec citation 20
Vieux 08/11/2011, 10h35   #3
Membre actif
 
Inscription : novembre 2005
Messages : 537
Détails du profil
Informations forums :
Inscription : novembre 2005
Messages : 537
Points : 198
Points : 198
OUi je veux ou voulais dénormaliser

Je n'ai pas pensé à la vue, merci !
J'ai un peu oublié mes cours.....
nath-0-0 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/11/2011, 10h43   #4
Membre Expert
 
Homme Sylvain Devidal
Chef de projets Générix
Inscription : février 2010
Messages : 1 062
Détails du profil
Informations personnelles :
Nom : Homme Sylvain Devidal
Âge : 33
Localisation : France, Rhône (Rhône Alpes)

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

Informations forums :
Inscription : février 2010
Messages : 1 062
Points : 1 515
Points : 1 515
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
StringBuilder est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/11/2011, 11h46   #5
Membre actif
 
Inscription : novembre 2005
Messages : 537
Détails du profil
Informations forums :
Inscription : novembre 2005
Messages : 537
Points : 198
Points : 198
merci pour le complément d'inforamtions !
nath-0-0 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 14h19.


 
 
 
 
Partenaires

Hébergement Web