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

MS SQL Server Discussion :

Modification de la base


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Août 2009
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 10
    Par défaut Modification de la base
    Bonjour,
    Ma base était sans conception, sans relations ni clé primaires.... des tables indépendantes et je faisais tout le travail coté code (VB).
    J'ai décidé de refaire tout le travail, coté base c'est fait mais il me reste de voir le code et les requêtes et je ne sais pas quoi modifier.
    Par exemple si j'ai crée une relation entre de tables es ce que je dois enlever les jointures entre elles?
    Merci

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    J'ai décidé de refaire tout le travail
    Et vous avez bien fait !

    Par exemple si j'ai crée une relation entre de tables es ce que je dois enlever les jointures entre elles?
    Vous confondez contraintes et jointures :
    - une contrainte, quel que soit son type, vous permet de garantir l'intégrité de vos données
    - une jointure vous permet de vraiment profiter de la puissance d'un modèle de données relationnel, en faisant participer plusieurs entités à la réponse à une question : votre requête

    Vous pouvez donc ajouter vos contraintes sans vous soucier de vos jointures.
    Veillez néanmoins à indexer proprement les colonnes qui sont clé étrangères, car l'ajout d'une telle contrainte entraîne bien sûr sa vérification, qui ne peut se faire rapidement que si la colonne est correctement indexée.

    @++

  3. #3
    Membre averti
    Inscrit en
    Août 2009
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 10
    Par défaut
    Merci, ok je vois bien ce que vous avez cité mais je ne sais pas encore c'est quoi l'effet des mes modifications sur mes requêtes et comment les adapter à cette nouvelle conception, mon but reste toujours l'optimisation.

  4. #4
    Membre Expert

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2007
    Messages
    1 216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Août 2007
    Messages : 1 216
    Par défaut
    Bonjour,

    Si vous aviez par exemple 2 tables:
    - Produit (id_produit, libelle, id_CategorieProduit_FK)
    - CategorieProduit (id_CategorieProduit, libelle)

    Et que ces tables ne contenaient pas de relations, ni de clefs... Et que vous aviez une query:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select ...
    from Produit join CategorieProduit on Produit.id_CategorieProduit_FK = CategorieProduit.id_CategorieProduit
    Apres la mise en place des clefs etrangeres, cette query reste valable.

    Donc d'apres moi, si vous avez juste rajouter des relations et des index et si votre code de base etait bien, vous ne devriez rien avoir a changer au niveau des queries.

    Les relations entre les tables n'affectent pas la maniere dont il faut les interroger, pareil pour les clefs primaires.

  5. #5
    Membre averti
    Inscrit en
    Août 2009
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 10
    Par défaut
    Donc au lieu de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT ...
    FROM Produit JOIN CategorieProduit ON Produit.id_CategorieProduit_FK = CategorieProduit.id_CategorieProduit
    je peux mettre?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT ...
    FROM Produit, CategorieProduit
    et j'aurai le même résultat?

  6. #6
    Membre Expert

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2007
    Messages
    1 216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Août 2007
    Messages : 1 216
    Par défaut
    Non, vous n'obtiendrez pas la meme chose.
    Les references garantissent l'integrite de vos donnees (une securite en plus pour ne pas pouvoir inserer n'importe quoi comme valeurs dans les colonnes de vos tables). Cela n'impacte en rien la maniere selon laquelle vous devez rediger vos queries. La jointure doit toujours etre presente dans votre query.

  7. #7
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT ...
    FROM Produit, CategorieProduit
    Cette requête vous retournera le produit cartésien des deux tables, ce qui n'est pas la même chose que

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT ...
    FROM Produit JOIN CategorieProduit ON Produit.id_CategorieProduit_FK = CategorieProduit.id_CategorieProduit
    Qui spécifie une équi-jointure.

    Dans tous les cas, vous devriez spécifier vos jointures par le mot-clé JOIN, même s'il s'agit d'un produit cartésien (CROSS JOIN).

    Pour aller un peu plus loin

    @++

Discussions similaires

  1. [Access 2003]Erreur modification données dans base distante
    Par Julio_del_pueblo dans le forum Access
    Réponses: 2
    Dernier message: 22/06/2006, 14h22
  2. Modification d'une base de donnée
    Par scorpion37 dans le forum C++Builder
    Réponses: 70
    Dernier message: 16/06/2006, 09h08
  3. Probleme de mise à jour et de modification d'une base
    Par flambo88 dans le forum Requêtes
    Réponses: 17
    Dernier message: 07/12/2005, 14h27
  4. Réponses: 6
    Dernier message: 26/09/2005, 10h38
  5. Modification d'une base Access avec MySQL
    Par Wyatt dans le forum Administration
    Réponses: 2
    Dernier message: 07/01/2005, 19h20

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