chapter 4: intermediate sql - tarleton state university€¦ · database system concepts - 6th...

86
Database System Concepts, 6 th Ed. ©Silberschatz, Korth and Sudarshan See www.db-book.com for conditions on re-use Chapter 4: Intermediate SQL

Upload: others

Post on 16-Jun-2020

4 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

Database System Concepts, 6th Ed.

©Silberschatz, Korth and Sudarshan

See www.db-book.com for conditions on re-use

Chapter 4: Intermediate SQL

Page 2: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 3: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 4: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 5: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 6: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 7: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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 %')

Page 8: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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?

Page 9: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.9 Database System Concepts - 6th Edition

Conclusion on ON

We are going to extend the concept of a

JOIN!

Page 10: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 11: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 12: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 13: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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?

Page 14: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 15: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.15 Database System Concepts - 6th Edition

Left Outer Join

course natural left outer join prereq

Page 16: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.16 Database System Concepts - 6th Edition

Right Outer Join

course natural right outer join prereq

Page 17: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.17 Database System Concepts - 6th Edition

Full Outer Join

course natural full outer join prereq

Page 18: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 19: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 20: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 21: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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!

Page 22: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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?)

Page 23: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 24: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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:

Page 25: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.25 Database System Concepts - 6th Edition

4.2 Views

Remember abstraction idea from Ch.1

Page 26: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 27: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 28: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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!

Page 29: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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:

Page 30: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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;

(

Page 31: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select 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.

Page 32: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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’;

Page 33: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 34: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 35: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 36: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.36 Database System Concepts - 6th Edition

NULL here!

Page 37: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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?

Page 38: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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) ?

Page 39: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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!

Page 40: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 41: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 42: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 43: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 44: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 45: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 46: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 47: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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;

Page 48: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 49: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 50: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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).

Page 51: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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’))

);

Page 52: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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”.

Page 53: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 54: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 55: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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!)

Page 56: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 57: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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!

Page 58: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.58 Database System Concepts - 6th Edition

Assertions

create assertion <assertion-name> check <predicate>;

What integrity condition is enforced here?

Page 59: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 60: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 61: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

)

)

Page 62: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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!

Page 63: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 64: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 65: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 66: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

)

Page 67: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 68: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 69: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 70: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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’));

Page 71: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 72: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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).

Page 73: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 74: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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.

Page 75: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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;

Page 76: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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?

Page 77: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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

Page 78: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©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)

Page 79: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.79 Database System Concepts - 6th Edition

Figure 4.01

Page 80: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.80 Database System Concepts - 6th Edition

Figure 4.02

Page 81: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.81 Database System Concepts - 6th Edition

Figure 4.03

Page 82: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.82 Database System Concepts - 6th Edition

Figure 4.04

Page 83: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.83 Database System Concepts - 6th Edition

Figure 4.05

Page 84: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.84 Database System Concepts - 6th Edition

Figure 4.07

Taylor

Page 85: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.85 Database System Concepts - 6th Edition

Figure 4.06

Page 86: Chapter 4: Intermediate SQL - Tarleton State University€¦ · Database System Concepts - 6th Edition 4.2 ©Silberschatz, Korth and Sudarshan Review of Joins (ch.3) select name,

©Silberschatz, Korth and Sudarshan 4.86 Database System Concepts - 6th Edition

Figure 4.03