Vues de base de données

Conception de bases de données

Lis Sulmont

Curriculum Manager

Vues de base de données

Dans une base de données, une vue est le résultat d'une requête stockée sur les données, que les utilisateurs de la base de données peuvent interroger comme ils le feraient dans un objet de collection de base de données permanent (Wikipédia)

Tableau virtuel qui ne fait pas partie du schéma physique

  • Ce sont les requêtes, et non les données, qui sont stockées en mémoire
  • Les données sont agrégées à partir des données contenues dans les tableaux
  • Peuvent être interrogées comme un tableau de base de données classique
  • Il n'est pas nécessaire de retaper les requêtes courantes ni de modifier les schémas
1 https://en.wikipedia.org/wiki/View_(SQL)
Conception de bases de données

Création d'une vue (syntaxe)

CREATE VIEW view_name AS
SELECT col1, col2 
FROM table_name 
WHERE condition;
Conception de bases de données

Création d'une vue (exemple)

Book dimension of the snowflake schema

$$

Objectif : Renvoyer les titres et les auteurs du genre science fiction

Conception de bases de données

Création d'une vue (exemple)

CREATE VIEW scifi_books AS
SELECT title,  author, genre
FROM dim_book_sf
JOIN dim_genre_sf ON dim_genre_sf.genre_id = dim_book_sf.genre_id
JOIN dim_author_sf ON dim_author_sf.author_id = dim_book_sf.author_id
WHERE dim_genre_sf.genre = 'science fiction';
Conception de bases de données

Interrogation d'une vue (exemple)

SELECT * FROM scifi_books
| title                         | author            | genre           |
|-------------------------------|-------------------|-----------------|
| The Naked Sun                 | Isaac Asimov      | science fiction |
| The Robots of Dawn            | Isaac Asimov      | science fiction |
| The Time Machine              | H.G. Wells        | science fiction |
| The Invisible Man             | H.G. Wells        | science fiction |
| The War of the Worlds         | H.G. Wells        | science fiction |
| Wild Seed (Patternmaster, #1) | Octavia E. Butler | science fiction |
| ...                           | ...               | ...             |
Conception de bases de données

À l’arrière-plan

SELECT * FROM scifi_books

=

SELECT * FROM 
(SELECT title,  author, genre
FROM dim_book_sf
JOIN dim_genre_sf ON dim_genre_sf.genre_id = dim_book_sf.genre_id
JOIN dim_author_sf ON dim_author_sf.author_id = dim_book_sf.author_id
WHERE dim_genre_sf.genre = 'science fiction');
Conception de bases de données

Affichage des vues

(dans PostgreSQL)

$$

SELECT * FROM INFORMATION_SCHEMA.views;

Comprend les vues du système

SELECT * FROM information_schema.views
WHERE table_schema NOT IN ('pg_catalog', 'information_schema');

Exclut les vues du système

Conception de bases de données

Avantages des vues

  • Ne nécessite pas d'espace de stockage
  • Une forme de contrôle d'accès
    • Masquer les colonnes sensibles et limiter les informations visibles par l'utilisateur
  • Masquer la complexité des requêtes
    • Utile pour les schémas hautement normalisés
Conception de bases de données

$$ Schema of Pitchfork Reviews Database

1 https://www.kaggle.com/nolanbconaway/pitchfork-data
Conception de bases de données

Passons à la pratique !

Conception de bases de données

Preparing Video For Download...