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 :

[SQL Server] Table ou vue?


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Avatar de strat0
    Homme Profil pro
    Développeur Web
    Inscrit en
    Novembre 2003
    Messages
    288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Novembre 2003
    Messages : 288
    Par défaut [SQL Server] Table ou vue?
    Bonjour,

    Je vous explique. Mon chef - qui a une bonne expérience du SQL mais qui n'est en aucun cas DBA administrator - m'a lancé sur un projet. Tout part d'une table qui contient les logs d'un serveur web (pas les logs W3C, quelque chose d'un peu plus évolué).

    Mon chef souhaite que je créé une autre table (totalement indépendante du reste de la base) qui traite ces logs pour en tirer des statistiques, chaque ligne représentant un mois, et chaque colonne un "type de média" (CD, vidéo..., mais ça n'a pas grande importance).

    Je lui ai proposé de faire plutôt une vue, puisque les données contenues dans cette table de statistiques sont redondantes, et que la table n'est reliée à rien. En effet, on m'a appris qu'une base de données ne devaient pas contenir de données "calculées", et théoriquement si la base est cohérente, il ne devrait pas y avoir ce genre de table indépendante.

    Mais mon chef redoute la charge que créerait cette vue à chaque appel, alors qu'une table fixe ne nécessiterait que le calcul d'une nouvelle ligne chaque fin de mois. Moi je pensais que les vues étaient faites pour ça.

    Alors qui a raison?

  2. #2
    Expert confirmé
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 932
    Par défaut
    LEs 2 discours se tiennent

    Quel sera la fréquence d'accès à cette table/vue ?

    Quel est le SGBD utilisé ?

  3. #3
    Membre éclairé
    Avatar de strat0
    Homme Profil pro
    Développeur Web
    Inscrit en
    Novembre 2003
    Messages
    288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Novembre 2003
    Messages : 288
    Par défaut
    Citation Envoyé par qi130 Voir le message
    Quel sera la fréquence d'accès à cette table/vue ?
    Très faible. C'est une table ou vue qu'on consulte une fois de temps en temps pour voir l'évolution de l'utilisation de notre site web. Justement je me demandes : est-ce qu'une vue est recalculée à chaque nouvelle ligne entrée dans la table de départ (c'est-à-dire très très souvent) ou juste quand on fait un SELECT dessus?
    Citation Envoyé par qi130 Voir le message
    Quel est le SGBD utilisé ?
    SQL Server 2000.

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 287
    Par défaut
    Citation Envoyé par strat0 Voir le message
    Justement je me demandes : est-ce qu'une vue est recalculée à chaque nouvelle ligne entrée dans la table de départ (c'est-à-dire très très souvent) ou juste quand on fait un SELECT dessus?
    Une vue ne contient pas de données. Elle est calculée à chaque fois qu'on fait un SELECT dessus, et seulement pour la partie interrogée.

  5. #5
    Expert confirmé
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 932
    Par défaut
    Il me semble que les vues matérialisées d'Oracle n'obéissent pas à cette règle...

    Mais bon, puisqu'Oracle n'est pas dans la course.... et vu le cahier des charges, une vue est à privilégier.

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 287
    Par défaut
    Citation Envoyé par qi130 Voir le message
    Il me semble que les vues matérialisées d'Oracle n'obéissent pas à cette règle...
    Yep. C'est pourquoi ce ne sont pas des vues, mais des tables avec diverses conditions de rafraîchissement.

Discussions similaires

  1. [SQL Server] Table cachée
    Par Riwalenn dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 29/11/2007, 09h08
  2. Réponses: 1
    Dernier message: 07/06/2007, 17h04
  3. Projet ADP + SQL Server : tables en lecture seule
    Par hannii dans le forum Access
    Réponses: 8
    Dernier message: 09/03/2007, 14h16
  4. Réponses: 2
    Dernier message: 27/12/2006, 13h31
  5. [SQL SERVER] Table contient trop d'enregistrements ?
    Par Tankian dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 10/08/2004, 10h40

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