Chapter 11 Creating and Managing Views
11.1 Creating Views
View
A view is a database object. Tey are not real tables. They are logical representations of existing
tables or of another view. They contain no data of their own. They function as a window through
which data from tables can be viewed or changed.
The tables on which a view is based are called base tables. The view is a query stored in a SELECT
statement in the data dictionary.
CREATE VIEW view_emplyoyees
AS SELECT first_name, last_name, email
FROM employees
WHERE employee_id BETWEEN 100 and 124;
Why Use Views?
Views restrict access to base table data because the view can display selective columns from the table.
Views can be used to reduce the complexity of executing queries based on more complicated SELECT
statements. For example, the creator of the view can construct join statements that retrieve data from
multiple tables. The user of the view neither sees the underlying code nor how to create it. The user,
through the view interacts with the database using simple queries.
Views can be used to retrieve data from several tables, providing data independence for users. Users
can view the same data in different ways.
Views provide groups of users with access to data according to their particular permissions or criteria.
Creating a view
To create a view, embed a subquery within the CREATE VIEW statement.
CREATE [OR REPLACE] [FORCE| NOFORCE] VIEW view [(alias [, alias]]...)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY [CONSTRAINT constraint]];
CREATE OR REPLACE VIEW view_of_animals
AS SELECT animal_name....;
CREATE [OR REPLACE] [FORCE| NOFORCE] VIEW view_name
[(alias [, alias]...)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY [CONSTRAINT constraint]];
OR REPLACE: Re-creates the view if it already exists
FORCE: Creates the view whether or not the base tables exist.
NOFORCE: Creates the view only if the base table exists (default).
view_name: Specifies the name of the view.
alias: Specifies a name for each expression selected by the view's query.
Subquery: Is a complete SELECT statement. You can use aliases for the columns in the SELECT list.
The subquery can contain complex SELECT syntax.
WITH CHECK OPTION: Specifies that only rows accessible to the view can be inserted or updated.
Constraint: Is the name assigned to the CHECK OPTION constraint.
WITH READ ONLY: Ensures that no DML operations can be performed on this view.
Guidelines for Creating a View
The subquery that defines the view can contain complex SELECT syntax.
The subquery that defines the view cannot contain an ORDER BY clause. The ORDER BY clause is
specified when you retrieve data from the view.
You can use the OR REPLACE option to change the definition of the view without having to drop it or
re-grant object privileges previously granted on it.
Aliases can be used for the column names in the subquery.
CREATE VIEW Features
Two classifications of views are used: simple and complex.
Simple View
CREATE VIEW view_copy_d_cds
AS SELECT cd_number, title, produer, year
FROM d_cds;
The view above is an example of a simple view. The subquery derives data from only one table and it
does not contain a join function or any group functions. Because it is a simple view, INSERT,
UPDATE, DELETE, and MERGE operations affecting the base table could possibly be performed
through the view.
Column names in the SELECT statement can have aliases as shown below. Note that alises can also be
listed after the CREATE VIEW statement and before the SELECT subquery.
CREATE VIEW view_copy_d_cds
AS SELECT cd_number AS Number, title AS Title', year AS Year_Recorded
FROM d_cds;
CREATE VIEW view_copy_d_cd (Number, Title, Year_Recorded)
AS SELECT cd_number, title, year
FROM d_cds;
It s possible to create a view whether or not the base tables exist. Adding the word FORCE to
CREATE VIEW statement creates the view.
Useful during development of a database. NOFORCE option is the default when creating a view.
Complex View
Complex views are views that can contan group functions and joins. The following example creates a
view that derives data from two tables.
CREATE VIEW view_dj_on_demand (LAST_NAME, TELEPHONE, EVENT, DATE_HELD)
AS SELECT c.last_name, c.phone, e.name,
TO_CHAR (e.event_date, 'Month dd, YYYY')
FROM d_clients c, d_events e
WHERE c.client_number = e.client_number;
Group functions can also be added to complex-view statements
Modifying a View
To modify an existing view without having to re-create it, use the OR REPLACE option in the
CREATE VIEW statement. The old view is replaced by the new version.
CREATE OR REPLACE VIEW view_copy_d_cds
AS SELECT cd_number, title, producer, year
FROM d_cds;
11.2 DML Operations and Views
DML Statements and Views
The DML operations INSERT, UPDATE, and DELETE can be performed on simple views. These
operations can be used to change the data in the underlying base tables. If you create a view that
allows users to view restricted information using the WHERE clause, users can still perform DML
operations on all columns of the view.
For example, the view shown below was created for the managers of department 50 from the oracle
database. The intent of this view is to allow managers of department 50 to see information about their
employees.
CREATE VIEW view_dept50 AS
SELECT department_id, employee_id, first_name, last_name, salary
FROM employees
WHERE department_id = 50;
Controlling Views
Using the view as stated, it is possible to INSERT, UPDATE, and DELETE information from all
departments.
This may not be what the DBA intended when the view was created.
To control data access, two options can be added to the CREATE VIEW statement:
WITH CHECK OPTION
WITH READ ONLY
Views with CHECK Option
The WITH CHECK OPTION ensures that DML operations performed on the view stay within the
domain of the view. Any attempt to change the department number for any row in the view fails
because it violates the WITH CHECK OPTION constraint. Notice in the example below that the
WITH CHECK OPTION CONSTRAINT was given the name view_dept50_check.
CREATE OR REPLACE VIEW view_dept50 AS
SELECT department_id, employee_id, first_name, last_name salary
FROM employees
WHERE department_id = 50
WITH CHECK OPTION CONSTRAINT view_dept50_check;
Views with READ ONLY
The WITH READ ONLY option ensures that no DML operations occur through the view. Any Attempt
to execute an INSERT, UPDATE, or DELETE statement will result in an Oracle server error.
CREATE OR REPLACE VIEW view_dept40 AS
SELECT department_id, employee_id, first_name, last_name, salary
FROM employees
WHERE department_id = 50
WITH READ ONLY;
DML Restrictions
Simple views and complex views differ in their ability to allow DML operations through a view. For
simple views, DML operations can be performed through the view. For complex views, DML
operations are not always allowed.
The following three rules must be considered when performing DML operations on views.
SELECT rownum, first_name
FROM employees
WHERE employee_id
BETWEEN 100 AND 105;
1. You cannot remove a row from an underlying base table if the view contains any of the following:
Group functions
A GROUP BY clause
The DISTINCT keyword
The peuodocolumn ROWNUM Keyword.
2. You cannot modify data through a view if the view contains:
Group functions
A GROUP BY clause
The DISTINCT keyword
The pseudocolumn ROWNUM keyword
Columns defined by expressions
3. you cannot add data through a view if the view
includes group functions
includes a GROUP BY clause
includes the DISTINCT keyword
includes the pseudocolumn ROWNUM keyword
includes columns defined by expressions
does not include NOT NULL coloumns in the base tables.
11.3 Managing Views
Deleting a View
Because a view contains no data of its own, removing it does not affect the data in the underlying
tables. If the view was used to INSERT, UPDATE, OR DELETE data in the past, those changes tot he
base tables remain.
Deleting a view simply removes the view definition from the database. Remember, views are stored as
SELECT statements in the data dictionary. Only the creator or users with the DROP ANY VIEW
privilege can remove a view.
DROP VIEW viewname;
Inline Views
Inline views are also referred to as subqueries in the FROM clause.
You insert a subquery in the FROM clause just as if the subquery was a table name.
Inline views are commonly used to simplify complex queries by removing join operations and
condensing several queries into one.
As shown in the example below, the FROM clause contains a SELECT statement that retrieves data
much like any SELECT statement. The data returned by the subquery is given an alias(p), which is
then used in conjunction with the main query to return selected columns from both query sources.
SELECT e.name, e.description, p.maxrange, p.code
FROM d_events e, (SELECT code, max(high_range) maxrange
FROM d_packages
GROUP BY code) p
WHERE e.package_code = p.code
AND e.cost < p.maxrange;
TOP-N-Analysis
Top-n-analysis is a SQL operation used to rank results. The use of top-n-analysis is useful when you
want to retrieve the top 4 records, or top-n records, or a result set returned by a query.
SELECT ROWNUM as RANK, year, title
FROM (SELECT year, title
FROM d_cds
ORDER BY year)
WHERE ROWNUM <= 4;
The top-n-analysis query uses an inline view (a subquery) to return a result set. You can use
ROWNUM in your query to assign a row number to the result set. The main query then uses
ROWNUM to order the data and return the top four.