Академический Документы
Профессиональный Документы
Культура Документы
Chapter 6 - Objectives
ata types supported by SQL standard.
ow to use the integrity enhancement feature in the CREATE and ALTER TABLE statements.
2
Chapter 6 - Objectives
urpose of views. ow to create and delete views using SQL. ow the DBMS performs operations on views. nder what conditions views are updatable. dvantages and disadvantages of views. ow the ISO transaction model works. ow to use the GRANT and REVOKE statements as
3
omain Constraints
(a) CHECK sex CHAR NOT NULL CHECK (sex IN (M, F))
CREATE DOMAIN SexType AS CHAR CHECK (VALUE IN (M, F)); sex SexType NOT NULL
7
UNIQUE(telNo)
FOREIGN Branch
KEY(branchNo)
REFERENCES
10
11
12
13
14
15
Data Definition
QL DDL allows database objects such as schemas, domains, tables, views, and indexes to be created and destroyed. ain SQL DDL statements are:
CREATE SCHEMA DROP SCHEMA CREATE/ALTER DOMAIN DROP DOMAIN CREATE/ALTER TABLE DROP TABLE CREATE VIEW DROP VIEW
any DBMSs also provide:
CREATE INDEX
DROP INDEX
16
Data Definition
elations and other database objects exist in an environment. ach environment contains one or more catalogs, and each catalog consists of set of schemas. chema is named collection of related database objects. bjects in a schema can be tables, views, domains, assertions, collations, translations, and character sets. All have same owner.
17
CREATE SCHEMA
CREATE SCHEMA [Name | AUTHORIZATION CreatorId ] DROP SCHEMA Name [RESTRICT CASCADE ]
ith RESTRICT (default), empty or operation fails. schema must
be
ith CASCADE, operation cascades to drop all objects associated with schema in order defined above. If any of these operations fail, DROP SCHEMA fails.
18
CREATE TABLE
CREATE TABLE TableName {(colName dataType [NOT NULL] [UNIQUE] [DEFAULT defaultOption] [CHECK searchCondition] [,...]} [PRIMARY KEY (listOfColumns),] {[UNIQUE (listOfColumns),] [,]} {[FOREIGN KEY (listOfFKColumns) REFERENCES ParentTableName [(listOfCKColumns)], [ON UPDATE referentialAction] [ON DELETE referentialAction ]] [,]} {[CHECK (searchCondition)] [,] })
19
CREATE TABLE
reates a table with one or more columns of the specified dataType. ith NOT NULL, system rejects any attempt to insert a null in the column. an specify a DEFAULT value for the column. rimary keys should always be specified as NOT NULL. OREIGN KEY clause specifies FK along with the referential action.
20
ownerNo staffNo
OwnerNumber
ALTER TABLE
dd a new column to a table. rop a column from a table. dd a new table constraint. rop a table constraint. et a default for a column. rop a default for a column.
23
24
LTER TABLE PropertyForRent DROP CONSTRAINT StaffNotHandlingTooMuch; LTER TABLE Client ADD prefNoRooms PRooms;
25
DROP TABLE
ROP TABLE TableName [RESTRICT | CASCADE] e.g. DROP TABLE PropertyForRent;
emoves named table and all rows within it. ith RESTRICT, if any other objects depend for their existence on continued existence of this table, SQL does not allow request. ith CASCADE, SQL drops all dependent objects (and objects dependent on these objects).
26
Views
iew
Dynamic result of one or more relational operations operating on base relations to produce another relation.
irtual relation that does not necessarily actually exist in the database but is produced upon request, at time of request.
27
Views
ontents of a view are defined as a query on one or more base relations. ith view resolution, any operations on view are automatically translated into operations on relations from which it is derived. ith view materialization, the view is stored as a temporary table, which is maintained as the underlying base tables are updated.
28
29
30
31
CREATE VIEW Staff3 AS SELECT staffNo, fName, lName, position, sex FROM Staff WHERE branchNo = B003;
32
CREATE VIEW StaffPropCnt (branchNo, staffNo, cnt) AS SELECT s.branchNo, s.staffNo, COUNT(*) FROM Staff s, PropertyForRent p WHERE s.staffNo = p.staffNo GROUP BY s.branchNo, s.staffNo;
33
34
35
36
View Resolution
Count number of properties managed by each member at branch B003.
SELECT staffNo, cnt FROM StaffPropCnt WHERE branchNo = B003 ORDER BY staffNo;
37
View Resolution
(a) View column names in SELECT list are translated into their corresponding column names in the defining query:
As
staffNo,
(b) View names in FROM are replaced with corresponding FROM lists of defining query:
38
View Resolution
(c) WHERE from user query is combined with
WHERE of defining query using AND:
p.staffNo
AND
(d) GROUP BY and HAVING clauses copied from GROUP BY s.branchNo, s.staffNo (e) ORDER BY copied from query with view column
name translated into defining query column name
ORDER BY s.staffNo
39
View Resolution
(f) Final merged query is now executed to produce the result:
SELECT s.staffNo AS staffNo, COUNT(*) AS cnt FROM Staff s, PropertyForRent p WHERE s.staffNo = p.staffNo AND branchNo = B003 GROUP BY s.branchNo, s.staffNo ORDER BY s.staffNo;
40
Restrictions on Views
SQL imposes several restrictions on creation and use of views. (a) If column in view is based on an aggregate function:
Column may appear only in SELECT and ORDER BY clauses of queries that access view. Column may not be used in WHERE nor be an argument to an aggregate function in any query based on view.
41
Restrictions on Views
or example, following query would fail:
SELECT COUNT(cnt) FROM StaffPropCnt;
42
Restrictions on Views
(b) Grouped view may never be joined with a base table or a view. For example, StaffPropCnt view is a grouped view, so any attempt to join this view with another table or view fails.
43
View Updatability
ll updates to base table reflected in all views that encompass base table. imilarly, may expect that if view is updated then base table(s) will reflect change.
44
View Updatability
owever, consider again view StaffPropCnt. f we tried to insert record showing that at branch B003, SG5 manages 2 properties:
INSERT INTO StaffPropCnt VALUES (B003, SG5, 2);
ave to insert 2 records into PropertyForRent showing which properties SG5 manages. However, do not know which properties they are; i.e. do not know primary keys!
45
View Updatability
f change definition of view and replace count with actual property numbers:
CREATE VIEW StaffPropList (branchNo, staffNo, propertyNo) AS SELECT s.branchNo, s.staffNo, p.propertyNo FROM Staff s, PropertyForRent p WHERE s.staffNo = p.staffNo;
46
View Updatability
ow try to insert the record:
INSERT INTO StaffPropList VALUES (B003, SG5, PG19);
till problem, because in PropertyForRent all columns except postcode/staffNo are not allowed nulls. owever, have no way of giving remaining nonnull columns values.
47
View Updatability
SO specifies that a view is updatable if and only if:
- DISTINCT is not specified. - Every element in SELECT list of defining query is a column name and no column appears more than once. - FROM clause specifies only one table, excluding any views based on a join, union, intersection or difference. - No nested SELECT referencing outer table.
48
Updatable View
For view to be updatable, DBMS must be able to trace any row or column back to its row or column in the source table.
49
51
CREATE VIEW LowSalary AS SELECT * FROM Staff WHERE salary > 9000; CREATE VIEW HighSalary AS SELECT * FROM LowSalary WHERE salary > 10000 WITH LOCAL CHECK OPTION; CREATE VIEW Manager3Staff AS SELECT * FROM HighSalary
53
his update would fail: although update would cause row to disappear from HighSalary, row would not disappear from LowSalary. owever, if update tried to set salary to 8000, update would succeed as row would no longer be part of LowSalary.
54
55
Advantages of Views
ata independence urrency mproved security educed complexity onvenience ustomization ata integrity
56
Disadvantages of Views
pdate restriction tructure restriction erformance
57
View Materialization
iew resolution mechanism may be particularly if view is accessed frequently. slow,
iew materialization stores view as temporary table when view is first queried. hereafter, queries based on materialized view can be faster than recomputing view each time. ifficulty is maintaining the currency of view while base tables(s) are being updated.
58
View Maintenance
iew maintenance aims to apply only changes necessary to keep view current. onsider following view: those
CREATE VIEW StaffPropRent(staffNo) AS SELECT DISTINCT staffNo FROM PropertyForRent WHERE branchNo = B003 AND rent > 400;
59
View Materialization
f insert row into PropertyForRent with rent 400 then view would be unchanged. f insert row for property PG24 at branch B003 with staffNo = SG19 and rent = 550, then row would appear in materialized view. f insert row for property PG54 at branch B003 with staffNo = SG37 and rent = 450, then no new row would need to be 60 added to materialized view.
Transactions
QL defines transaction model based on COMMIT and ROLLBACK. ransaction is logical unit of work with one or more SQL statements guaranteed to be atomic with respect to recovery. n SQL transaction automatically begins with a transaction-initiating SQL statement (e.g., SELECT, INSERT). hanges made by transaction are not visible to other concurrently executing transactions until transaction completes.
61
Transactions
ransaction can complete in one of four ways:
62
Transactions
ew transaction starts with next transactioninitiating statement. QL transactions cannot be nested. ET TRANSACTION configures transaction:
READ
63
64
Immediate Constraints
and
Deferred
Integrity
ET CONSTRAINTS statement used to set mode for specified constraints for current transaction:
SET CONSTRAINTS
{ALL | constraintName [, . . . ]} {DEFERRED IMMEDIATE}
65
Privileges
ctions user permitted to carry out on given base table or view: ELECT NSERT PDATE ELETE Retrieve data from a table. Insert new rows into a table. Modify rows of data in a table. Delete rows of data from a table. of named
67
Privileges
an restrict INSERT/UPDATE/REFERENCES to named columns. wner of table must grant other users the necessary privileges using GRANT statement. o create view, user must have SELECT privilege on all tables that make up view and REFERENCES privilege on the named columns.
68
GRANT
GRANT {PrivilegeList | ALL PRIVILEGES} ON ObjectName TO {AuthorizationIdList | PUBLIC} [WITH GRANT OPTION]
rivilegeList consists of one or more of above privileges separated by commas. LL PRIVILEGES grants all privileges to a user.
69
GRANT
UBLIC allows access to be granted to all present and future authorized users. bjectName can be a base table, view, domain, character set, collation or translation. ITH GRANT passed on. OPTION allows privileges to be
70
72
REVOKE
EVOKE takes away privileges granted with GRANT. REVOKE [GRANT OPTION FOR] {PrivilegeList | ALL PRIVILEGES} ON ObjectName FROM {AuthorizationIdList | PUBLIC} [RESTRICT | CASCADE] LL PRIVILEGES granted to a refers to all privileges user by user revoking73
REVOKE
RANT OPTION FOR allows privileges passed on via WITH GRANT OPTION of GRANT to be revoked separately from the privileges themselves. EVOKE fails if it results in an abandoned object, such as a view, unless the CASCADE keyword has been specified. rivileges granted to this user by other users are not affected.
74
REVOKE
75