Lecture 5 Data Definition Language (DDL)

Similar documents
Lecture 6 Structured Query Language (SQL)

Standard Query Language. SQL: Data Definition Transparencies

Example 1 - Create Horizontal View. Example 2 - Create Vertical View. Views. Views

3ISY402 DATABASE SYSTEMS

Lecture 07. Spring 2018 Borough of Manhattan Community College

DB Creation with SQL DDL

Transforming ER to Relational Schema

STRUCTURED QUERY LANGUAGE (SQL)

Chapter 6. SQL Data Manipulation

COMP102: Introduction to Databases, 5 & 6

ADVANCED QUERY AND VIEWS

CS317 File and Database Systems

CS317 File and Database Systems

CMP-3440 Database Systems

COSC 304 Introduction to Database Systems. Views and Security. Dr. Ramon Lawrence University of British Columbia Okanagan

Lecture 03. Spring 2018 Borough of Manhattan Community College

CS317 File and Database Systems

Relational Algebra and Relational Calculus. Pearson Education Limited 1995,

Views. COSC 304 Introduction to Database Systems. Views and Security. Creating Views. Views Example. Removing Views.

Slides by: Ms. Shree Jaswal

Chapter 6. SQL: SubQueries

Chapter 4. Basic SQL. Copyright 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley

Lecture 7 Stored procedure

Lecture 03. Fall 2017 Borough of Manhattan Community College

D B M G. SQL language: basics. Managing tables. Creating a table Modifying table structure Deleting a table The data dictionary Data integrity

Lecture7: SQL Overview, Oracle Data Type, DDL and Constraints Part #2

Basic SQL. Basic SQL. Basic SQL

Chapter 1 SQL and Data

Chapter 3. The Relational database design

Lecture7: SQL Overview, Oracle Data Type, DDL and Constraints Part #2

Conceptual Database Design

Copyright 2016 Ramez Elmasri and Shamkant B. Navathe

Lab # 4. Data Definition Language (DDL)

COSC344 Database Theory and Applications. Lecture 5 SQL - Data Definition Language. COSC344 Lecture 5 1

OBJECTIVES. How to derive a set of relations from a conceptual data model. How to validate these relations using the technique of normalization.

CMP-3440 Database Systems

Relational Data Model ( 관계형데이터모델 )

CS317 File and Database Systems

SQL Fundamentals. Chapter 3. Class 03: SQL Fundamentals 1

SQL STRUCTURED QUERY LANGUAGE

RELATIONAL DATA MODEL

SQL (Structured Query Language) Truong Tuan Anh CSE-HCMUT

SQL (Structured Query Language) Truong Tuan Anh CSE-HCMUT

Lab # 2. Data Definition Language (DDL) Eng. Alaa O Shama

Chapter 5. Relational Algebra and Relational Calculus

Chapter 4. Basic SQL. SQL Data Definition and Data Types. Basic SQL. SQL language SQL. Terminology: CREATE statement

CMP-3440 Database Systems

Institute of Southern Punjab, Multan

CMP-3440 Database Systems

Physical Database Design

Data Modelling and Databases. Exercise Session 7: Integrity Constraints

Data Definition Language (DDL)

Database Technologies. Madalina CROITORU IUT Montpellier

SQL: A COMMERCIAL DATABASE LANGUAGE. Complex Constraints

Basic SQL. Dr Fawaz Alarfaj. ACKNOWLEDGEMENT Slides are adopted from: Elmasri & Navathe, Fundamentals of Database Systems MySQL Documentation

Lecture2: Database Environment

Data about data is database Select correct option: True False Partially True None of the Above

Database design process

The Relational Model

Where are we? Week -4: Data definition (Creation of the schema) Week -3: Data definition (Triggers) Week -1: Transactions and concurrency in ORACLE.

Database Systems. A Practical Approach to Design, Implementation, and Management. Database Systems. Thomas Connolly Carolyn Begg

SQL: A COMMERCIAL DATABASE LANGUAGE. Data Change Statements,

COSC 304 Introduction to Database Systems SQL DDL. Dr. Ramon Lawrence University of British Columbia Okanagan

Database Technologies. Madalina CROITORU IUT Montpellier

Lecture 08. Spring 2018 Borough of Manhattan Community College

Introduction to SQL. ECE 650 Systems Programming & Engineering Duke University, Spring 2018

Chapter 4. The Relational Model


Concepts of Database Management Seventh Edition. Chapter 4 The Relational Model 3: Advanced Topics

Solved MCQ on fundamental of DBMS. Set-1

Where Are We? Next Few Lectures. Integrity Constraints Motivation. Constraints in E/R Diagrams. Keys in E/R Diagrams

More SQL: Complex Queries, Triggers, Views, and Schema Modification

Query Processing Transparencies. Pearson Education Limited 1995, 2005

SQL. Char (30) can store ram, ramji007 or 80- b

Relational Data Structure and Concepts. Structured Query Language (Part 1) The Entity Integrity Rules. Relational Data Structure and Concepts

CSC 261/461 Database Systems Lecture 6. Fall 2017

Structured Query Language (SQL)

Lecture 01. Fall 2018 Borough of Manhattan Community College

Introduction to Database Systems CSE 414

CS317 File and Database Systems

Logical Database Design. ICT285 Databases: Topic 06

Indexes (continued) Customer table with record numbers. Source: Concepts of Database Management

More SQL: Complex Queries, Triggers, Views, and Schema Modification

Islamic University of Gaza Faculty of Engineering Department of Computer Engineering Fall 2011 ECOM 4113: Database System Lab Eng.

SQL: Data De ni on. B0B36DBS, BD6B36DBS: Database Systems. h p:// Lecture 3

2.9 Table Creation. CREATE TABLE TableName ( AttrName AttrType, AttrName AttrType,... )

doc. RNDr. Tomáš Skopal, Ph.D. RNDr. Michal Kopecký, Ph.D.

5 Integrity Constraints and Triggers

A <column constraint> is a constraint that applies to a single column.

Constraints. Primary Key Foreign Key General table constraints Domain constraints Assertions Triggers. John Edgar 2

Database Management System Dr. S. Srinath Department of Computer Science & Engineering Indian Institute of Technology, Madras Lecture No.

Data analysis and design Unit number: 23 Level: 5 Credit value: 15 Guided learning hours: 60 Unit reference number: H/601/1991.

More SQL: Complex Queries, Triggers, Views, and Schema Modification

Outline. Textbook Chapter 6. Note 1. CSIE30600/CSIEB0290 Database Systems Basic SQL 2

COSC344 Database Theory and Applications. Lecture 6 SQL Data Manipulation Language (1)

CSIE30600 Database Systems Basic SQL 2. Outline

EGCI 321: Database Systems. Dr. Tanasanee Phienthrakul

Unit 1 - Chapter 4,5

B.H.GARDI COLLEGE OF MASTER OF COMPUTER APPLICATION. Ch. 1 :- Introduction Database Management System - 1

Integrity and Security

Transcription:

ITM-661 ระบบฐานข อม ล (Database system) Walailak - 2013 Lecture 5 Data Definition Language (DDL) Walailak University T. Connolly, and C. Begg, Database Systems: A Practical Approach to Design, Implementation, and Management, 5th edition, Addison-Wesley, 2010. ISBN: 0-321-60110-6, ISBN-13: 978-0-321-60110-0 (International Edition). T. Connolly, and C. Begg, Database Systems: A Practical Approach to Design, Implementation, and Management, 4th edition, Addison-Wesley, 2004. ISBN: 0-321-21025-5. R. Elmasri and S. B. Navathe, Fundamentals of Database Systems, 5th ed., Pearson, 2007, ISBN: 0-321-41506-X.

Objectives Integrity Enhancement Feature How to use the integrity enhancement feature in the CREATE and ALTER TABLE statements. How to create and delete views using SQL. How the DBMS performs operations on views. Under what conditions views are updatable. Advantages and disadvantages of views. How to use GRANT/REVOKE statements as a level of security. 2

ISO SQL Data Types and Data Definition In SQL92, relations and other database objects exist in an environment. Each environment contains one or more catalogs, and each catalog consists of set of schemas. Schema is a named collection of related database objects. Objects in a schema can be tables, views, domains, assertions, collations, translations, and character sets. All have same owner. 3 ITS322 - DBMSs Lecture 4: SQLs (Continued)

Integrity Enhancement Feature Consider five types of integrity constraints: Required data. Domain constraints. Entity integrity. Referential integrity. Enterprise constraints. 4

CREATE SCHEMA CREATE SCHEMA [Name AUTHORIZATION CreatorId ] DROP SCHEMA Name [RESTRICT CASCADE ] With RESTRICT (default), schema must be empty or operation fails. With CASCADE, operation cascades to drop all objects associated with schema in the order defined above. If any of these operations fail, DROP SCHEMA fails. 5 ITS322 - DBMSs Lecture 4: SQLs (Continued)

CREATE TABLE CREATE DOMAIN OwnerNumber AS VARCHAR(5) CHECK (VALUE IN (SELECT ownerno FROM PrivateOwner)); CREATE DOMAIN StaffNumber AS VARCHAR(5) CHECK (VALUE IN (SELECT staffno FROM Staff)); CREATE DOMAIN PNumber AS VARCHAR(5) CREATE DOMAIN PRooms AS SMALLINT; CHECK (VALUE BETWEEN 1 AND 15); CREATE DOMAIN PRent AS DECIMAL(6,2) CREATE TABLE PropertyForRent ( propertyno CHECK PNumber (VALUE BETWEEN NOT NULL, 0 AND. 9999.99); rooms PRooms NOT NULL DEFAULT 4, rent PRent NOT NULL DEFAULT 600, ownerno OwnerNumber NOT NULL, staffno StaffNumber Constraint StaffNotHandlingTooMuch. branchno BranchNumber NOT NULL, PRIMARY KEY (propertyno), FOREIGN KEY (staffno) REFERENCES Staff (staffno) ON DELETE SET NULL ON UPDATE CASCADE.); 6

Integrity Enhancement Feature (Required Data and Domain Constraints) Required Data position VARCHAR(10) NOT NULL Domain Constraints (a) CHECK (b) CREATE DOMAIN sex CHAR NOT NULL CHECK (sex IN ( M, F )) CREATE DOMAIN SexType AS CHAR CHECK (VALUE IN ( M, F )); sex SexType NOT NULL 7

Integrity Enhancement Feature (Domain Constraints Continued) searchcondition can involve a table lookup: CREATE DOMAIN BranchNo AS CHAR(4) CHECK (VALUE IN (SELECT branchno FROM Branch)); Domains can be removed using DROP DOMAIN: DROP DOMAIN DomainName [RESTRICT CASCADE] 8

Integrity Enhancement Feature (Entity Integrity) Primary key of a table must contain a unique, non-null value for each row. ISO standard supports PRIMARY KEY clause in CREATE and ALTER TABLE statements: PRIMARY KEY (staffno) PRIMARY KEY (clientno, propertyno) Can only have one PRIMARY KEY clause per table. Can still ensure uniqueness for alternate keys using UNIQUE: UNIQUE(telNo) 9

Integrity Enhancement Feature (Referential Integrity) FK is column or set of columns that links each row in child table containing foreign FK to row of parent table containing matching PK. Referential integrity means that, if FK contains a value, that value must refer to existing row in parent table. ISO standard supports definition of FKs with FOREIGN KEY clause in CREATE and ALTER TABLE: FOREIGN KEY (branchno) REFERENCES Branch 10

Integrity Enhancement Feature (Referential Integrity Constraint Types) Any INSERT/UPDATE that attempts to create FK value in child table without matching candidate key value in parent is rejected. Action taken that attempts to update/delete a candidate key value in parent table with matching rows in child is dependent on referential action specified using ON UPDATE and ON DELETE subclauses: 11 CASCADE SET NULL SET DEFAULT NO ACTION

Integrity Enhancement Feature (Referential Integrity - Detail) CASCADE Delete row from parent and delete matching rows in child, and so on in cascading manner. SET NULL Delete row from parent and set FK column(s) in child to NULL. Only valid if FK columns are NOT NULL. SET DEFAULT Delete row from parent and set each component of FK in child to specified default. Only valid if DEFAULT specified for FK columns NO ACTION Reject delete from parent. Default. 12

Integrity Enhancement Feature (Referential Integrity How to use) How to use referential integrity FOREIGN KEY (staffno) REFERENCES Staff ON DELETE SET NULL FOREIGN KEY (ownerno) REFERENCES Owner ON UPDATE CASCADE 13

Integrity Enhancement Feature (Enterprise Constraints) Could use CHECK/UNIQUE in CREATE and ALTER TABLE. CREATE ASSERTION AssertionName CHECK (searchcondition) which is very similar to the CHECK clause. An example 14 CREATE ASSERTION StaffNotHandlingTooMuch CHECK (NOT EXISTS ( SELECT staffno FROM PropertyForRent GROUP BY staffno HAVING COUNT(*) > 100))

CREATE TABLE (I) 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)] [, ] }) 15 ITS322 - DBMSs Lecture 4: SQLs (Continued)

CREATE TABLE (II) Creates a table with one or more columns of the specified data_type. NULL (default) indicates whether column can contain nulls. With NOT NULL, system rejects any attempt to insert a null in the column. Can specify a DEFAULT value for the column. Primary keys should always be specified as NOT NULL. Foreign keys are often (but not always) candidates for NOT NULL. FOREIGN KEY clause specifies FK along with the referential action 16 ITS322 - DBMSs Lecture 4: SQLs (Continued)

CREATE TABLE CREATE DOMAIN OwnerNumber AS VARCHAR(5) CHECK (VALUE IN (SELECT ownerno FROM PrivateOwner)); CREATE DOMAIN StaffNumber AS VARCHAR(5) CHECK (VALUE IN (SELECT staffno FROM Staff)); CREATE DOMAIN PNumber AS VARCHAR(5) CREATE DOMAIN PRooms AS SMALLINT; CHECK (VALUE BETWEEN 1 AND 15); CREATE DOMAIN PRent AS DECIMAL(6,2) CHECK (VALUE BETWEEN 0 AND 9999.99); CREATE TABLE propertyforrent ( propertyno PNumber NOT NULL,. rooms PRooms NOT NULL DEFAULT 4, rent PRent NOT NULL,DEFAULT 600, ownerno OwnerNumber NOT NULL, 17 staffno StaffNumber Constraint StaffNotHandlingTooMuch. branchno BranchNumber NOT NULL, PRIMARY KEY (propertyno), FOREIGN KEY (staffno) REFERENCES Staff ON DELETE SET NULL ON UPDATE CASCADE.); ITS322 - DBMSs Lecture 4: SQLs (Continued)

DROP TABLE DROP TABLE TableName [RESTRICT CASCADE] For example, DROP TABLE PropertyForRent; Removes named table and all rows within it. With RESTRICT, if any other objects depend for their existence on continued existence of this table, SQL does not allow request. With CASCADE, SQL drops all dependent objects (and objects dependent on these objects). 18 ITS322 - DBMSs Lecture 4: SQLs (Continued)

ALTER TABLE (I) Add a new column to a table. Drop a column from a table. Add a new table constraint. Drop a table constraint. Set a default for a column. Drop a default for a column. 19 ITS322 - DBMSs Lecture 4: SQLs (Continued)

ALTER TABLE (II) ALTER TABLE TableName {ADD [COLUMN] colname datatype [NOT NULL][UNIQUE] [DEFAULT defaultoption] [CHECK searchcondition] [,...]} [DROP [COLUMN] colname [RESTRICT CASCADE]] [ADD [CONSTRAINT [ConstrName]] tblconstrdef] [DROP CONSTRAINT ConstrName [RESTRICT CASCADE]] [ALTER [COLUMN] SET DEFAULT DefaultOption] [ALTER [COLUMN] DROP DEFAULT] RESTRICT: The DROP operation is reject if the column is referenced by another DB object. It is the default setting. CASCADE: The DROP operation proceeds and automatically drops the column from any DB objects it is referenced by. 20 ITS322 - DBMSs Lecture 4: SQLs (Continued)

ALTER TABLE (III) Change Staff table by removing default of Assistant for position column and setting default for sex column to female ( F ). ALTER TABLE Staff ALTER position DROP DEFAULT; ALTER TABLE Staff ALTER sex SET DEFAULT F ; 21 ITS322 - DBMSs Lecture 4: SQLs (Continued)

ALTER TABLE (IV) Remove constraint from PropertyForRent that staff are not allowed to handle more than 100 properties at a time. Add new column to Client table. ALTER TABLE PropertyForRent DROP CONSTRAINT StaffNotHandlingTooMuch; ALTER TABLE Client ADD prefnorooms INT; 22 ITS322 - DBMSs Lecture 4: SQLs (Continued)

ALTER TABLE (V) Change Staff table by removing default of 'Assistant' for Position column and setting default for Sex column to female ('F'). 23 ALTER TABLE staff ALTER position DROP DEFAULT; ALTER TABLE staff ALTER sex SET DEFAULT 'F'; Removing constraint that staff not allowed to handle more than 10 properties at a time from Property_for_Rent. ALTER TABLE property_for_rent DROP CONSTRAINT staff_not_handling_too_much; Add new column to Renter representing preferred area for accommodation. ALTER TABLE renter ADD pref_area VARCHAR(15);

View Dynamic result of one or more relational operations operating on the base relations to produce another relation. Virtual relation that does not actually exist in the database but is produced upon request, at time of request. Contents of a view are defined as a query on one or more base relations. Any operations on view are automatically translated into operations on relations from which it is derived. 24

SQL - Create View CREATE VIEW view_name [ (column_name [,...]) ] AS subselect [WITH [CASCADED LOCAL] CHECK OPTION] Can assign a name to each column in view. If list of column names is specified, it must have same number of items as number of columns produced by subselect. If omitted, each column takes name of corresponding column in subselect. WITH CHECK OPTION ensures that if a row fails to satisfy WHERE clause of defining query, it is not added to underlying base table. Need SELECT privilege on all of tables referenced in the subselect and USAGE privilege on any domains used in referenced columns. 25

Create Horizontal View Create a view so that the manager at branch B3 can only see details for staff who work in his or her office. CREATE VIEW Manager3Staff AS SELECT * FROM Staff WHERE branchno = 'B003'; 26

Create Vertical View Create view of staff details at branch B003 excluding salaries. CREATE VIEW Staff3 AS SELECT staffno, fname, lname, position, sex FROM Staff WHERE branchno = B003 ; CREATE VIEW Staff3 AS SELECT staffno, fname, lname, position, sex FROM Manager3Staff; 27

Grouped and Joined Views Create view of staff who manage properties for rent, including branch number they work at, staff number, and number of properties they manage. 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; 28

SQL - DROP VIEW DROP VIEW view_name [RESTRICT CASCADE] Causes definition of view to be deleted from the database. DROP VIEW Manager3Staff; With CASCADE, all related dependent objects are deleted; i.e. any views defined on view being dropped. With RESTRICT (default), if any other objects depend for their existence on continued existence of view being dropped, command is rejected. 29

View Resolution Count number of properties managed by each member at branch B003. SELECT staffno, cnt FROM StaffPropCnt WHERE branchno = B003 ORDER BY staffno; 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; 30

View Resolution (a) View column names in SELECT list are translated into their corresponding column names in the defining query: SELECT s.staffno AS staffno, COUNT(*) AS cnt (b) View names in FROM are replaced with corresponding FROM lists of defining query: 31 FROM Staff s, PropertyForRent p (c) WHERE from user query is combined with WHERE of defining query using AND: WHERE s.staffno = p.staffno AND branchno = 'B003 (d) GROUP BY and HAVING clauses copied from defining query: GROUP BY s.staffno, s.branchno (e) ORDER BY copied from query with view column name translated into defining query column name ORDER BY s.staffno

View Resolution Final merged query is now executed to produce the result: SELECT s.staffno, COUNT(*) FROM Staff s, PropertyForRent p WHERE s.staffno = p.staffno AND s.branchno = 'B003' GROUP BY s.staffno, s.branchno ORDER BY s.staffno; SELECT staffno, cnt FROM StaffPropCnt WHERE branchno = 'B003' ORDER BY staffno; 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; 32

Restrictions on Views SQL-92: 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. For example, following query would fail: SELECT COUNT(cnt) FROM StaffPropCnt; SELECT * FROM StaffPropCnt WHERE cnt > 2; 33

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. The following statement fails. SELECT COUNT(cnt) FROM StaffPropCnt c, Staff s WHERE c.staffno =s.staffno; 34

View Updatability All updates to base table reflected in all views that encompass base table. Similarly, may expect that if view is updated then base table(s) will reflect change. However, consider view StaffPropCnt: 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; 35

View Updatability If tried to insert record showing that at branch B3, SG5 manages 2 properties: INSERT INTO StaffPropCnt VALUES ('B003', 'SG5', 2); Have to insert 2 records into Property_for_Rent showing which properties SG5 manages. However, do not know which properties they are; i.e. do not know primary keys! 36

View Updatability If 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; Trying to insert the record: INSERT INTO staffproplist VALUES ('B003', 'SG5', 'PG19'); Still problem, because in PropertyForRent all columns except postcode/staffno are not allowed nulls. However, have no way of giving remaining non-null columns values. 37

38 View Updatability SQL-92 specifies the views that must be updatable in system that conforms to standard. Definition given is that a view is updatable iff: 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. WHERE clause does not include any nested SELECTs that reference the table in FROM clause. There is no GROUP BY or HAVING clause in the defining query. Every row added through view must not violate integrity constraints of base table. Be able to trace back to its row and column in the source tables.

Pros and Cons of Views Data Independence Currency Security Reduced Complexity Convenience Customization Data Integrity Advantages Update Restriction Structure Restriction Performance 39 Disadvantage

Access Control (Authorization Identifiers and Ownership) Authorization identifier is normal SQL identifier used to establish identity of a user. Usually, has an associated password. Used to determine which objects user may reference and what operations may be performed on those objects. Each object created in SQL has an owner, as defined in AUTHORIZATION clause of schema to which the object belongs. Owner is only person who may know about it. 40

Privileges Actions allowed on given base table or view: SELECT INSERT UPDATE DELETE REFERENCES USAGE translations. 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. Reference columns of a table in integrity constraints. Use domains, collations, character sets, and Can restrict INSERT/UPDATE/REFERENCES to columns. Owner of table must grant other users the necessary privileges using GRANT statement. To create view, user must have SELECT privilege on all tables that make up view and REFERENCES privilege on the named columns. 41

GRANT (I) GRANT {PrivilegeList ALL PRIVILEGES} ON ObjectName TO {AuthorizationIdList PUBLIC} [WITH GRANT OPTION] privilege_list consists of one or more of the above privileges separated by commas. SELECT DELETE INSERT [(col_name [, ])] UPDATE [(col_name [, ])] REFERENCES [(col_name [, ])] USAGE ALL PRIVILEGES grants all privileges to a user. 42

GRANT (II) PUBLIC allows access to be granted to all present and future authorized users. object_name can be a base table, view, domain, character set, collation or translation. WITH GRANT OPTION allows privileges to be passed on. Ex.: give Manager full privileges to Staff table. GRANT ALL PRIVILEGES ON Staff TO Manager WITH GRANT OPTION; 43

GRANT Specific Privileges Give Admin SELECT and UPDATE on column Salary of Staff. GRANT SELECT, UPDATE (salary) ON Staff TO Admin; Give users Personnel and Deputy SELECT on Staff table. GRANT SELECT ON Staff TO Personnel, Deputy; Give all users SELECT on Branch table. GRANT SELECT ON Branch TO PUBLIC; 44

REVOKE (I) REVOKE takes away privileges granted with GRANT. REVOKE [GRANT OPTION FOR] {PrivilegeList ALL PRIVILEGES} ON ObjectName FROM {AuthorizationIdList PUBLIC} [RESTRICT CASCADE] ALL PRIVILEGES refers to all privileges granted to a user by user revoking privileges. 45

REVOKE (II) GRANT OPTION FOR allows privileges passed on via WITH GRANT OPTION of GRANT to be revoked separately from the privileges themselves. REVOKE fails if it results in an abandoned object, such as a view, unless the CASCADE keyword has been specified. (such as a view cannot be created if no privilege) Privileges granted to this user by other users are not affected by REVOKE but we can use 46 CASCADE.

REVOKE (III) 47

REVOKE Specific Privileges Revoke privilege SELECT on Branch table from all users. REVOKE SELECT ON Branch FROM PUBLIC; Revoke all privileges given to Deputy on Staff table. REVOKE ALL PRIVILEGES ON Staff FROM Deputy; 48

Exercise 5-1 : View Resolution What is the difference between a view and a base relation? Show the view solution result of the following view definition and query. SELECT bname, maxsal FROM BranchMaxMinSalary WHERE bno LIKE %B0% ORDER BY bname; 49 CREATE VIEW BranchMaxMinSalary (bno, bname, maxsal, minsal) AS SELECT b.branchno, b.branchname, MAX(s.salary), MIN(s.salary) FROM Staff s, Branch b WHERE s.branchno = b.branchno GROUP BY b.branch.id, b.branchname ;

Exercise 5-2 : Restrictions on View Given the following view CREATE VIEW BranchMaxMinSalary (bno, bname, maxsal, minsal) AS SELECT b.branchno, b.branchname, MAX(s.salary), MIN(s.salary) FROM Staff s, Branch b WHERE s.branchno = b.branchno GROUP BY b.branch.id, b.branchname ; Are the following queries valid based on SQL-92? SELECT bname, maxsal FROM BranchMaxMinSalary WHERE maxsal >=100 ORDER BY bname; SELECT bname, minsal FROM BranchMaxMinSalary b, PropertyForRent p WHERE b.branchno=p.branchno AND p.propertyno= PG14 50

Exercise 5-3 : View Updatability What is view updatability? Explain the result of the following view update. CREATE VIEW BranchSum (bno, sumsal) AS SELECT b.branchno, SUM(s.salary) FROM Staff s, Branch b WHERE s.branchno=b.branchno; UPDATE BranchSum SET sumsal = sumsal*1.05 WHERE bno = B002'; Explain the result of the following view update. CREATE VIEW StaffB01 (sno, fn, sal) AS SELECT s.staffno, s.fname, s.salary FROM Staff s WHERE s.branchno LIKE %B01% ; 51 UPDATE StaffB01 SET sal = sal*1.05 WHERE sal < 1000;

Exercise 5-4 : Privileges Let the following privilege-related SQL statements be executed. UserA (1) UserB (2) UserC (3) UserD (5) (4) UserE (1) GRANT ALL PRIVILEGES ON TableA TO UserB WITH GRANT OPTION (2) GRANT SELECT, UPDATE ON TableA TO UserC WITH GRANT OPTION (3) GRANT SELECT, UPDATE ON TableA TO UserD (4) GRANT SELECT ON TableA TO UserC (5) REVOKE SELECT ON TableA FROM UserB CASCADE Describe the privileges of UserB, UserC and UserD on TableA Fill Y if the user has a privilege and fill N if the user has no privilege 52