In some cases, it is not desirable for all users to see the entire logical model (i.e., all the actual relations stored in the database).
Aside from security concerns, one may wish to create personalised collection of relations that is better matched to a certain user’s intuition than is the logical model.
SQL allows a virtual relation to be defined by a query, and the relation conceptually contains the result of the query.
Any such relation that is not part of the logical model, but is made visible to a user as a virtual relation, is called a view.
View definition
A view is defined using the CREATE VIEW
statement.
v
: The name of the viewQ
: Any legal SQL expression
Once a view is defined, the view name can be used to refer to the virtual relation that the view generates.
View denition is not the same as creating a new relation by evaluating the query expression. Rather, a view definition causes the saving of an expression; the expression is substituted into queries using the view.
Examples
- A view of instructors without their salary
- Find all instructors in the Biology department
- A view of department salary totals
Views defined using other views
A view can be used in the expression defining another view.
-
Direct dependency
A view relation is said to depend directly on a view relation , if is used in the expression defining .
-
Dependency
A view relation is said to depend on a view relation , if either depends directly to , or there exists a path of dependencies from to .
-
Recursion
A view relation is said to be recursive if it depends on itself.
View expansion
View expansion is a way to define the meaning of views defined in terms of other views.
Suppose that a view is defined by an expression that may itself contain uses of view relations.
It follows the following replacement step:
REPEAT
Find any view relation v_i in e_1
Replace the view relation v_i by the expression defining v_i
UNTIL nomore view relation are present in e_1
As long as the view definitions are not recursive, the loop will terminate eventually.
Materialised views
Certain database systems allow view relations to be physically stored, that is, a physical copy of the ‘virtual’ relation is created when the view is defined.
Such views are called materialised views. It is especially efficient for views that are very commonly used.
If relations used in the query are updated, the materialised view reult becomes out of date; views must be maintained to date by updating the view whenever the underlying relations are updated.
Pros and cons of materialised views
Virtual Relation | Materialisation | |
---|---|---|
Pros | No updated required | No query rewriting required |
Cons | Queries must be rewrited every time | Update required whenever the base relations are updated |