chapter 4: intermediate sql - tarleton state university€¦ · database system concepts - 6th...
TRANSCRIPT
Database System Concepts, 6th Ed.
©Silberschatz, Korth and Sudarshan
See www.db-book.com for conditions on re-use
Chapter 4: Intermediate SQL
©Silberschatz, Korth and Sudarshan 4.2 Database System Concepts - 6th Edition
Review of Joins (ch.3)
select name, course_id
from instructor, teaches
where instructor.ID = teaches.ID
select section.course_id, semester, year, title
from section, course
where section.course_id = course.course_id and
dept_name = ‘Comp. Sci.'
select name, title
from instructor natural join teaches, course
where teaches.course_id = course.course_id
select name, title
from (instructor natural join teaches)
join course using(course_id)
©Silberschatz, Korth and Sudarshan 4.3 Database System Concepts - 6th Edition
More General Joining Conditions
Create a table of room numbers associated
with all the section IDs that were ever taught
in those numbers.
©Silberschatz, Korth and Sudarshan 4.4 Database System Concepts - 6th Edition
More General Joining Conditions
Create a table of room numbers associated with all
the section IDs that were ever taught in those
numbers.
select C.room_no, S.sec_if
from (section AS S join classroom AS C
using(room_no)
©Silberschatz, Korth and Sudarshan 4.5 Database System Concepts - 6th Edition
More General Joining Conditions
Create a table of room numbers associated with all
the section IDs that were ever taught in those
numbers.
select C.room_no, S.sec_if
from (section AS S join classroom AS C
using(room_no)
What if room_no does not have the same
name in both tables?
Rewrite query using WHERE clause … or
©Silberschatz, Korth and Sudarshan 4.6 Database System Concepts - 6th Edition
More General Joining Conditions
Create a table of room numbers associated with all
the section IDs that were ever taught in those
numbers.
What if room_no does not have the same
name in both tables?
Rewrite query using WHERE clause!
Use ON clause:
select C.room_no, S.sec_if
from (section AS S join classroom AS C
ON(C.room_no = S.room_no)
©Silberschatz, Korth and Sudarshan 4.7 Database System Concepts - 6th Edition
More General Joining Conditions
ON clause accepts any SQL predicate (AND,
OR, LIKE, BETWEEN, <=, etc.)
select C.room_no, S.sec_if
from (section AS S join classroom AS C
ON(C.room_no >= S.room_no AND
building LIKE 'Haunted %')
©Silberschatz, Korth and Sudarshan 4.8 Database System Concepts - 6th Edition
Conclusion on ON
Everything that can be achieved with
ON can also be achieved by using the
predicate in a WHERE clause.
… so what’s the point?
©Silberschatz, Korth and Sudarshan 4.9 Database System Concepts - 6th Edition
Conclusion on ON
We are going to extend the concept of a
JOIN!
©Silberschatz, Korth and Sudarshan 4.10 Database System Concepts - 6th Edition
Recap. of Joined Relations
Join operations take two relations and return as a
result another relation.
A join operation is a Cartesian product which
requires that tuples in the two relations match (under
some condition). It also specifies the attributes that
are present in the result of the join.
The join operations are typically used as subquery
expressions in the FROM clause.
©Silberschatz, Korth and Sudarshan 4.11 Database System Concepts - 6th Edition
Join operations – Example
Relation course
Relation prereq
Observe that
prereq information is missing for CS-315 and
course information is missing for CS-347
©Silberschatz, Korth and Sudarshan 4.12 Database System Concepts - 6th Edition
Join operations – Example
Relation course
Relation prereq
Write a query that returns all courses and their prerequisites.
Write a query that returns all courses in prereq and their
information.
©Silberschatz, Korth and Sudarshan 4.13 Database System Concepts - 6th Edition
Join operations – Example
Relation course
Relation prereq
Write a query that returns all courses and their prerequisites.
What happens with CS-315?
Write a query that returns all courses in prereq and their
information. What happens with CS-437?
©Silberschatz, Korth and Sudarshan 4.14 Database System Concepts - 6th Edition
Outer Join
An extension of the join operation that avoids loss
of information.
Computes the join and then adds tuples form one
relation that does not match tuples in the other
relation to the result of the join.
Uses null values.
©Silberschatz, Korth and Sudarshan 4.15 Database System Concepts - 6th Edition
Left Outer Join
course natural left outer join prereq
©Silberschatz, Korth and Sudarshan 4.16 Database System Concepts - 6th Edition
Right Outer Join
course natural right outer join prereq
©Silberschatz, Korth and Sudarshan 4.17 Database System Concepts - 6th Edition
Full Outer Join
course natural full outer join prereq
©Silberschatz, Korth and Sudarshan 4.18 Database System Concepts - 6th Edition
Outer Joined Relations
Left Outer Join preserves tuples only on left relation
Right Outer Join preserves tuples only on right relation
Full Outer Join preserves tuples in both relations
Join type – defines how tuples in each relation that do not
match any tuple in the other relation (based on the join
condition) are treated.
©Silberschatz, Korth and Sudarshan 4.19 Database System Concepts - 6th Edition
Joined Relations – Examples
course inner join prereq on
course.course_id = prereq.course_id
What is the difference between the above, and a natural join?
course left outer join prereq on
course.course_id = prereq.course_id
©Silberschatz, Korth and Sudarshan 4.20 Database System Concepts - 6th Edition
Joined Relations – Examples
course natural right outer join prereq
course full outer join prereq using (course_id)
©Silberschatz, Korth and Sudarshan 4.21 Database System Concepts - 6th Edition
To do for next time
Read the different outer join examples in
section 4.1.2 of text.
Understand!
©Silberschatz, Korth and Sudarshan 4.22 Database System Concepts - 6th Edition
QUIZ: Outer Joins
Write a query to display a list of all students (ID,name,
department name, total credits), along with the
courses they have taken.
Hint: SELECT *
FROM student NATURAL JOIN takes
does not work for all cases (Why?)
©Silberschatz, Korth and Sudarshan 4.23 Database System Concepts - 6th Edition
Practice Exercise 4.2
Rewrite
SELECT * FROM student
NATURAL LEFT OUTER JOIN takes
without using OUTER JOIN expression.
Hint: An outer join is an inner join with some
extra tuples added; use UNION.
©Silberschatz, Korth and Sudarshan 4.24 Database System Concepts - 6th Edition
Practice Exercise 4.2
Rewrite
SELECT * FROM student
NATURAL LEFT OUTER JOIN takes
without using OUTER JOIN expression.
Hint:
©Silberschatz, Korth and Sudarshan 4.25 Database System Concepts - 6th Edition
4.2 Views
Remember abstraction idea from Ch.1
©Silberschatz, Korth and Sudarshan 4.26 Database System Concepts - 6th Edition
4.2 Views
In some cases, it is not desirable for all users to see the entire
logical model (that is, all the actual relations stored in the
database.)
Consider a person who needs to know an instructors name
and department, but not the salary. This person should see a
relation described, in SQL, by
select ID, name, dept_name
from instructor
A view provides a mechanism to hide certain data from the
view of certain users.
Any relation that is not of the conceptual model but is made
visible to a user as a “virtual relation” is called a view.
©Silberschatz, Korth and Sudarshan 4.27 Database System Concepts - 6th Edition
View Definition
A view is defined using
CREATE VIEW v AS < query expression >
where <query expression> is any legal SQL expression. The view
name is represented by v.
Once a view is defined, the view name can be used to refer to the
virtual relation that the view generates.
View definition 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 that use the view.
A view is permanently deleted using
DROP VIEW v
©Silberschatz, Korth and Sudarshan 4.28 Database System Concepts - 6th Edition
Example Views
A view of instructors … what is missing?
create view faculty as (
select ID, name, dept_name
from instructor
)
The view is listed
in the catalog!
©Silberschatz, Korth and Sudarshan 4.29 Database System Concepts - 6th Edition
Find all instructors in the Biology department:
select name
from faculty
where dept_name = ‘Biology’
create view faculty as (
select ID, name, dept_name
from instructor
)
We can now use the view as a table to write queries:
©Silberschatz, Korth and Sudarshan 4.30 Database System Concepts - 6th Edition
Example Views
Create a view of department salary totals
create view dept_tot_sal(dept_name, total_salary) as (
select dept_name, sum (salary)
from instructor
group by dept_name;
(
©Silberschatz, Korth and Sudarshan 4.31 Database System Concepts - 6th Edition
QUIZ: Views
Write a view that displays a list of all course sections
(course_id, sec_id, semester, year), along with the
average grade made by the students in that section.
©Silberschatz, Korth and Sudarshan 4.32 Database System Concepts - 6th Edition
Views Defined Using Other Views
create view physics_fall_2009 as
select course.course_id, sec_id, building,
room_number
from course, section
where course.course_id = section.course_id
and course.dept_name = ’Physics’
and section.semester = ’Fall’
and section.year = ’2009’;
create view physics_fall_2009_watson as
select course_id, room_number
from physics_fall_2009
where building= ’Watson’;
©Silberschatz, Korth and Sudarshan 4.33 Database System Concepts - 6th Edition
How is this process implemented in SQL?
Think about the C preprocessor …
create view physics_fall_2009 as
select course.course_id, sec_id, building,
room_number
from course, section
where course.course_id = section.course_id
and course.dept_name = ’Physics’
and section.semester = ’Fall’
and section.year = ’2009’;
create view physics_fall_2009_watson as
select course_id, room_number
from physics_fall_2009
where building= ’Watson’;
This is called view expansion
©Silberschatz, Korth and Sudarshan 4.34 Database System Concepts - 6th Edition
Views Defined Using Other Views
-terminology-
A view relation v1 is said to depend directly on a
view relation v2 if v2 is used in the expression
defining v1
A view relation v1 is said to depend on view relation
v2 if either v1 depends directly to v2 or there is a
path of dependencies from v1 to v2
A view relation v is said to be recursive if it depends
on itself.
©Silberschatz, Korth and Sudarshan 4.35 Database System Concepts - 6th Edition
Problem: Updating Views
Add a new tuple to this view:
insert into faculty values (’30765’, ’Green’, ’Music’);
This insertion requires insertion of the tuple
(’30765’, ’Green’, ’Music’, NULL)
into the instructor relation.
A view of instructors without their salary
create view faculty as
select ID, name, dept_name
from instructor
©Silberschatz, Korth and Sudarshan 4.36 Database System Concepts - 6th Edition
NULL here!
©Silberschatz, Korth and Sudarshan 4.37 Database System Concepts - 6th Edition
Next problem: Some updates cannot be
translated uniquely
create view instructor_info as
select ID, name, building
from instructor, department
where instructor.dept_name =
department.dept_name;
insert into instructor_info values
(’69987’, ’White’, ’Taylor’);
which department, if multiple
departments in Taylor?
what if no department is in Taylor?
©Silberschatz, Korth and Sudarshan 4.38 Database System Concepts - 6th Edition
Next problem: Some updates should not
be allowed at all!
create view history_instructors as
select *
from instructor
where dept_name= ’History’;
What happens if we insert into this view the tuple
(’25566’, ’Brown’, ’Biology’, 100000) ?
©Silberschatz, Korth and Sudarshan 4.39 Database System Concepts - 6th Edition
create view history_instructors as
select *
from instructor
where dept_name= ’History’;
What happens if we insert into this view the tuple
(’25566’, ’Brown’, ’Biology’, 100000) ?
If we allow insertion, the inserted tuple does not appear in the view!
Should someone using this view even be allowed to insert
instructors working in a different department?
Conclusion: Don’t allow the insertion!
©Silberschatz, Korth and Sudarshan 4.40 Database System Concepts - 6th Edition
Conclusion on updating views
Most SQL implementations allow updates only on simple
views, e.g.
The from clause has only one database relation.
The select clause contains only attribute names of the
relation, and does not have any expressions,
aggregates, or distinct specification.
Any attribute not listed in the select clause can be set
to null
The query does not have a group by or having
clause.
©Silberschatz, Korth and Sudarshan 4.41 Database System Concepts - 6th Edition
Materialized Views
Materializing a view = creating a physical table
containing all the tuples in the result of the query
defining the view
This is different from the default view expansion
mentioned before!
Pro: Faster, b/c view does not need to be re-
computed every time it is mentioned
Con: If the relations used are updated, the
materialized view result becomes out of date
Need to maintain the view, by updating the view
whenever the underlying relations are updated.
©Silberschatz, Korth and Sudarshan 4.42 Database System Concepts - 6th Edition
4.3 Transactions
Unit of work
Atomic transaction
either fully executed or rolled back as if it never occurred
Why do we need this? Example: transfer money between
accounts.
Isolation from concurrent transactions
Transactions begin implicitly
Ended by COMMIT or ROLLBACK
But default on most databases: each SQL statement commits
automatically
Can turn off auto commit for a session (e.g. using API)
In SQL:1999, can use: begin atomic …. end
Not supported on most databases
©Silberschatz, Korth and Sudarshan 4.43 Database System Concepts - 6th Edition
Transactions in PostgreSQL
In PostgreSQL, a transaction is set up by surrounding the SQL
commands of the transaction with BEGIN and COMMIT
commands. So our banking transaction would look like:
BEGIN;
UPDATE accounts SET balance = balance - 100.00
WHERE name = 'Alice';
-- etc etc
COMMIT;
If, partway through the transaction, we decide we do not want to
commit (perhaps we just noticed that Alice's balance went
negative), we can issue the command ROLLBACK instead of
COMMIT, and all our updates so far will be canceled.
©Silberschatz, Korth and Sudarshan 4.44 Database System Concepts - 6th Edition
Transactions in PostgreSQL
BEGIN;
UPDATE accounts SET balance = balance - 100.00
WHERE name = 'Alice';
-- etc etc
COMMIT;
PostgreSQL treats every SQL statement as being
executed within a transaction.
If you do not issue a BEGIN command, then each
individual statement has an implicit BEGIN and (if
successful) COMMIT wrapped around it.
A group of statements surrounded by BEGIN and
COMMIT is sometimes called a transaction block.
©Silberschatz, Korth and Sudarshan 4.45 Database System Concepts - 6th Edition
Transactions in PostgreSQL
Actually, PostgreSQL also provides a more granular mechanism:
SAVEPOINTS:
BEGIN;
UPDATE accounts SET balance = balance - 100.00
WHERE name = 'Alice';
SAVEPOINT my_savepoint;
UPDATE accounts SET balance = balance + 100.00
WHERE name = 'Bob';
-- oops ... Should have used Wally's account
ROLLBACK TO my_savepoint;
UPDATE accounts SET balance = balance + 100.00 WHERE
name = 'Wally';
COMMIT;
Source: http://www.postgresql.org/docs/9.1/static/tutorial-transactions.html
©Silberschatz, Korth and Sudarshan 4.46 Database System Concepts - 6th Edition
QUIZ: Transactions in PostgreSQL
Write a PostgreSQL query that increases the
salaries of all instructors in the CS dept. by
6%, and those of all instructors in the Biology
dept. by 5% atomically
©Silberschatz, Korth and Sudarshan 4.47 Database System Concepts - 6th Edition
QUIZ: Transactions in PostgreSQL
Write a PostgreSQL script that increases the
salaries of all instructors in the CS dept. by
6%, and those of all instructors in the Biology
dept. by 5% atomically
BEGIN;
UPDATE instructor SET salary = salary * 1.06
WHERE dept_name = 'CS';
UPDATE instructor SET salary = salary * 1.05
WHERE dept_name = 'Biology';
COMMIT;
©Silberschatz, Korth and Sudarshan 4.48 Database System Concepts - 6th Edition
4.4 Integrity Constraints
They guard against accidental damage to the DB, by
ensuring that changes do not result in a loss of data
consistency, e.g.
A checking account must have a balance greater than
$10,000.00
A salary of a bank employee must be at least $4.00 an
hour
A customer must have a (non-null) phone number
©Silberschatz, Korth and Sudarshan 4.49 Database System Concepts - 6th Edition
Integrity Constraints on a Single Relation
not null
primary key
unique
check (P), where P is a predicate
They can all be included in CREATE TABLE
©Silberschatz, Korth and Sudarshan 4.50 Database System Concepts - 6th Edition
Not Null and Unique Constraints
not null
Declare name and budget to be not null
name varchar(20) not null
budget numeric(12,2) not null
unique ( A1, A2, …, Am)
The unique specification states that the attributes A1,
A2, … Am
form a candidate key.
Candidate keys are permitted to be null (in contrast
to primary keys).
©Silberschatz, Korth and Sudarshan 4.51 Database System Concepts - 6th Edition
CHECK clause
check (P)
where P is a predicate
Example: ensure that semester is one of Fall, Winter, Spring or Summer:
create table section (
course_id varchar (8),
sec_id varchar (8),
semester varchar (6),
year numeric (4,0),
building varchar (15),
room_number varchar (7),
time slot id varchar (4),
primary key (course_id, sec_id, semester, year),
check (semester in (’Fall’, ’Winter’, ’Spring’, ’Summer’))
);
©Silberschatz, Korth and Sudarshan 4.52 Database System Concepts - 6th Edition
Constraints on two relations:
Referential Integrity
Ensures that a value that appears in
one relation for a given set of
attributes also appears for a certain
set of attributes in another relation.
Example: If “Biology” is a department
name appearing in one (or more) of
the tuples in the instructor relation,
then there exists a (unique!) tuple in
the department relation for “Biology”.
©Silberschatz, Korth and Sudarshan 4.53 Database System Concepts - 6th Edition
Constraints on two relations:
Referential Integrity
Let A be a set of attributes. Let R
and S be two relations that
contain attributes A and where A
is the primary key of S. A is said
to be a foreign key of R if for
any values of A appearing in R
these values also appear in S.
©Silberschatz, Korth and Sudarshan 4.54 Database System Concepts - 6th Edition
Cascading Actions in Referential Integrity
create table course (
course_id char(5) primary key,
title varchar(20),
dept_name varchar(20) references department
)
create table course (
…
dept_name varchar(20),
foreign key (dept_name) references department
on delete cascade
on update cascade,
. . .
)
alternative actions to cascade: set null, set default
©Silberschatz, Korth and Sudarshan 4.55 Database System Concepts - 6th Edition
Cascading Actions in Referential Integrity
Problem 4.9
create table manager (
employee_name varchar(20) NOT NULL,
manager_name varchar(20) NOT NULL,
PRIMARY KEY employee_name,
FOREIGN KEY (manager_name) references
manager
on delete cascade
)
What happens when a tuple is deleted? (any tuple!)
©Silberschatz, Korth and Sudarshan 4.56 Database System Concepts - 6th Edition
Integrity Constraint Violation During
Transactions create table person (
ID char(10),
name char(40),
mother char(10),
father char(10),
primary key ID,
foreign key father references person,
foreign key mother references person)
How to insert a tuple without causing constraint violation ?
insert father and mother of a person before inserting person
OR, set father and mother to null initially, update after
inserting all persons (not possible if father and mother
attributes declared to be not null)
OR defer constraint checking (next slide)
©Silberschatz, Korth and Sudarshan 4.57 Database System Concepts - 6th Edition
Complex Check Clauses
check (time_slot_id in (select time_slot_id from time_slot))
why not use a foreign key here?
Every section has at least one instructor teaching the section.
how to write this?
Subquery in check clause not supported by pretty much any
DBMS
“CHECK is meant to handle constraints on a row's value in
isolation.”
Alternatives: triggers and functions (later)
Another alternative: assertions
SQL standard says that the predicate can
be anything, including a subquery!
©Silberschatz, Korth and Sudarshan 4.58 Database System Concepts - 6th Edition
Assertions
create assertion <assertion-name> check <predicate>;
What integrity condition is enforced here?
©Silberschatz, Korth and Sudarshan 4.59 Database System Concepts - 6th Edition
Assertions
create assertion <assertion-name> check <predicate>;
A: All tuples in student must have total credit equal to the sum of
credits for the classes successfully completed.
©Silberschatz, Korth and Sudarshan 4.60 Database System Concepts - 6th Edition
QUIZ: Assertions
An instructor cannot teach two different sections in the
same year, semester and time slot.
©Silberschatz, Korth and Sudarshan 4.61 Database System Concepts - 6th Edition
QUIZ: Assertions
An instructor cannot teach two different sections in the
same year, semester and time slot.
CREATE ASSERTION non-ubiquity CHECK (
UNIQUE (
SELECT T.ID, T.semester, T.year, S.time_slot_id
FROM teaches AS T NATURAL JOIN section AS S
)
)
©Silberschatz, Korth and Sudarshan 4.62 Database System Concepts - 6th Edition
Individual work
An instructor cannot teach two different sections in the
same year, semester and time slot and different
classrooms.
CREATE ASSERTION non-ubiquity CHECK (
UNIQUE (
SELECT T.ID, T.semester, T.year, S.time_slot_id
FROM teaches AS T NATURAL JOIN section AS S
)
)
Explanation: We don’t want to prevent instructors from teaching
multiple sections of the same class in the same room!
©Silberschatz, Korth and Sudarshan 4.63 Database System Concepts - 6th Edition
4.5 SQL Data Types and Schemas
Remember the basic data types (Sec.3.2):
char(n)
varchar(n)
int
smallint
numeric(p,d) (user-specified precision)
real, double precision (machine-dependent precision)
float(n) (user-specified precision)
©Silberschatz, Korth and Sudarshan 4.64 Database System Concepts - 6th Edition
4.5 SQL Data Types and Schemas
More data types: date and time
date → calendar date yyyy-mm-dd
time → hh:mm:ss
timestamp → combination date + time
Example: 2013-02-21 9:10:59.45-6
Fractions of a
second are
optional
Timezone
is
optional
©Silberschatz, Korth and Sudarshan 4.65 Database System Concepts - 6th Edition
Built-in Data Types in SQL
interval → period of time
Subtracting a date/time/timestamp value from
another gives an interval value
Interval values can be added to date/time/timestamp
values, e.g.
http://www.postgresql.org/docs/9.1/static/functions-datetime.html
©Silberschatz, Korth and Sudarshan 4.66 Database System Concepts - 6th Edition
Default values
create table student (
ID varchar (5),
name varchar (20) not null,
dept_name varchar (20), default ‘qwerty’
tot_cred numeric (3,0) default 0,
primary key (ID)
)
©Silberschatz, Korth and Sudarshan 4.67 Database System Concepts - 6th Edition
Index Creation
create table student
(ID varchar (5),
name varchar (20) not null,
dept_name varchar (20),
tot_cred numeric (3,0) default 0,
primary key (ID))
create index studentID_index on student(ID)
Index = data structure used to speed up access to records with
specified values for index attributes, e.g.
select * from student where ID = ‘12345’;
More details on indices in Chapter 11
©Silberschatz, Korth and Sudarshan 4.68 Database System Concepts - 6th Edition
Large-Object Types
Large objects (photos, videos, CAD files, etc.) are stored
as a large object:
blob: binary large object -- object is a large
collection of uninterpreted binary data (i.e. its
interpretation is left to an application outside of the
DB system)
clob: character large object -- object is a large
collection of character data
When a query returns a large object, a pointer is
returned rather than the large object itself.
CLOB is implemented as text
in PostgreSQL (up to 1 GB)
©Silberschatz, Korth and Sudarshan 4.69 Database System Concepts - 6th Edition
User-Defined Types
create type construct
Example:
create type Dollars as numeric (12,2) final;
create table department
(dept_name varchar (20),
building varchar (15),
budget Dollars
);
Not needed in
PostgreSQL
See Building your own custom type – pp.72-3 in our PostgreSQL book
©Silberschatz, Korth and Sudarshan 4.70 Database System Concepts - 6th Edition
Domains
create domain construct in SQL-92 creates user-defined
domain types
create domain person_name char(20) not null
Types and domains are similar. Domains can have
constraints, such as not null, specified on them.
create domain degree_level varchar(10)
constraint degree_level_test
check (value in (’Bachelors’, ’Masters’, ’Doctorate’));
©Silberschatz, Korth and Sudarshan 4.71 Database System Concepts - 6th Edition
4.6 Authorization
Forms of authorization on parts of the database:
Read - allows reading, but not modification of data.
Insert - allows insertion of new data, but not modification of existing
data.
Update - allows modification, but not deletion of data.
Delete - allows deletion of data.
Forms of authorization to modify the database schema
Index - allows creation and deletion of indices.
Resources - allows creation of new relations.
Alteration - allows addition or deletion of attributes in a relation.
Drop - allows deletion of relations.
©Silberschatz, Korth and Sudarshan 4.72 Database System Concepts - 6th Edition
Authorization Specification in SQL
The grant statement is used to confer authorization
grant <privilege list>
on <relation name or view name> to <user list>
<user list> is:
a user-id
public, which allows all valid users the privilege granted
A role (more on this later)
Granting a privilege on a view does not imply granting any
privileges on the underlying relations.
The grantor of the privilege must already hold the privilege on
the specified item (or be the database administrator).
©Silberschatz, Korth and Sudarshan 4.73 Database System Concepts - 6th Edition
Privileges in SQL
select: allows read access to relation,or the ability to query
using the view
Example: grant users U1, U2, and U3 select
authorization on the instructor relation:
grant select on instructor to U1, U2, U3
insert: the ability to insert tuples
update: the ability to update using the SQL update
statement
delete: the ability to delete tuples.
all privileges: used as a short form for all the allowable
privileges
©Silberschatz, Korth and Sudarshan 4.74 Database System Concepts - 6th Edition
Revoking Authorization in SQL
The revoke statement is used to revoke authorization.
revoke <privilege list>
on <relation name or view name> from <user list>
Example:
revoke select on branch from U1, U2, U3
<privilege-list> may be all to revoke all privileges the revokee
may hold.
If <revokee-list> includes public, all users lose the privilege
except those granted it explicitly.
If the same privilege was granted twice to the same user by
different grantees, the user may retain the privilege after the
revocation.
All privileges that depend on the privilege being revoked are
also revoked.
©Silberschatz, Korth and Sudarshan 4.75 Database System Concepts - 6th Edition
Roles
create role instructor;
grant instructor to Amit;
Privileges can be granted to roles:
grant select on takes to instructor;
Roles can be granted to users, as well as to other roles
create role teaching_assistant
grant teaching_assistant to instructor;
Instructor inherits all privileges of teaching_assistant
Chain of roles
create role dean;
grant instructor to dean;
grant dean to Satoshi;
©Silberschatz, Korth and Sudarshan 4.76 Database System Concepts - 6th Edition
Authorization on Views
create view geo_instructor as
(select *
from instructor
where dept_name = ’Geology’);
grant select on geo_instructor to geo_staff
Suppose that a geo_staff member issues
select *
from geo_instructor;
What if
geo_staff does not have permissions on instructor?
creator of view did not have some permissions on
instructor?
©Silberschatz, Korth and Sudarshan 4.77 Database System Concepts - 6th Edition
Chapter 4: Intermediate SQL
-review-
Join Expressions (JOIN … ON and
OUTER JOINs)
Views
Transactions
Integrity Constraints (FKs and CHECK)
SQL Data Types and Schemas
Authorization
©Silberschatz, Korth and Sudarshan 4.78 Database System Concepts - 6th Edition
Homework for Ch.4 Due Thursday, March 5
--End of chapter: 4.1, 4.3, 4.12, 4.14,
4.16 (Hint: CHECK), 4.18
--Table with all SQL constructs from ch.4,
each used in an example (OK if
example is from text)
©Silberschatz, Korth and Sudarshan 4.79 Database System Concepts - 6th Edition
Figure 4.01
©Silberschatz, Korth and Sudarshan 4.80 Database System Concepts - 6th Edition
Figure 4.02
©Silberschatz, Korth and Sudarshan 4.81 Database System Concepts - 6th Edition
Figure 4.03
©Silberschatz, Korth and Sudarshan 4.82 Database System Concepts - 6th Edition
Figure 4.04
©Silberschatz, Korth and Sudarshan 4.83 Database System Concepts - 6th Edition
Figure 4.05
©Silberschatz, Korth and Sudarshan 4.84 Database System Concepts - 6th Edition
Figure 4.07
Taylor
©Silberschatz, Korth and Sudarshan 4.85 Database System Concepts - 6th Edition
Figure 4.06
©Silberschatz, Korth and Sudarshan 4.86 Database System Concepts - 6th Edition
Figure 4.03