52
Informatik f¨ ur ¨ Okonomen II Fall 2010 Database Systems SQL SL03 Data Definition Language Table Expressions, Query Specifications, Query Expressions Subqueries, Duplicates, Null Values Modification of the Database Inf4Oec10, SL03 1/52 M. B¨ohlen, ifi@uzh

Database Systems SQL - UZH · Informatik fu¨r Okonomen II¨ Fall 2010 Database Systems SQL SL03 Data Definition Language Table Expressions, Query Specifications, Query Expressions

  • Upload
    dotuong

  • View
    219

  • Download
    0

Embed Size (px)

Citation preview

Informatik fur Okonomen II

Fall 2010

Database SystemsSQLSL03

◮ Data Definition Language

◮ Table Expressions, Query Specifications, Query Expressions

◮ Subqueries, Duplicates, Null Values

◮ Modification of the Database

Inf4Oec10, SL03 1/52 M. Bohlen, ifi@uzh

Checking...

1. Assume R(A) = {(1), (2), (3)}. Write a relational algebra expressionthat determines the larges value in R.

R

A

1

2

3

R1

A B

1 1

1 2

1 3

2 1

2 2

2 3

3 1

3 2

3 3

R2

A B

1 2

1 3

2 3

R3

A

3

R1← R × ρ(B)(R)

R2← σA<B(R1)

R3← R − πA(R2)

Inf4Oec10, SL03 2/52 M. Bohlen, ifi@uzh

Checking...

1. Identify and fix mistakes in the following relational algebraexpressions. Assume a relation with schema R(A,B).

σR.A>5(R)R.A is not an attribute name. Fix: σA>5(R)

σA,B(R)Selection requires predicate. Fix: πA,B(R)

R × R

Name clashes. Fix: ρT (R × ρS(C ,D)(R))

Inf4Oec10, SL03 3/52 M. Bohlen, ifi@uzh

History

◮ IBM Sequel language developed as part of System R project at theIBM San Jose Research Laboratory

◮ Renamed Structured Query Language (SQL)

◮ ANSI and ISO standard SQL:◮ SQL-86◮ SQL-89◮ SQL-92 (also called SQL2)

◮ entry level: roughly corresponds to SQL-89◮ intermediate level: half of the new features of SQL-92◮ full level

◮ SQL:2003 (also called SQL3)

◮ Commercial systems offer most, if not all, SQL-92 features, plusvarying feature sets from later standards and special proprietaryfeatures.

Inf4Oec10, SL03 4/52 M. Bohlen, ifi@uzh

Model and Terminology

◮ SQL is based on multisets (or bags) rather than sets. In a multisetan element may occur multiple times.

◮ SQL uses the terms table, column, and row.

◮ Comparison of terminology:

SQL Algebra

table relation

column attribute

row tuple

query relational algebra expression

◮ In SQL there is no distinction between small and capital characters.

Inf4Oec10, SL03 5/52 M. Bohlen, ifi@uzh

Data Definition Language

Allows the specification of not information about each table, including:

◮ The schema for each table.

◮ The domain associated with each column.

◮ Integrity constraints that all valid instances must satisfy.

◮ The set of indices to be maintained for each table.

◮ Security and authorization information for each table.

◮ The physical storage structure of each table on disk.

Inf4Oec10, SL03 6/52 M. Bohlen, ifi@uzh

Domain Types in SQL

char(n) Fixed length character string, with user-specified length n.

varchar(n) Variable length character strings, with user-specifiedmaximum length n.

integer Integer (a finite subset of the integers that ismachine-dependent).

smallint Small integer (a machine-dependent subset of the integerdomain type).

numeric(p,d) Fixed point number, with user-specified precision of pdigits, with n digits to the right of decimal point.

real, double precision Floating point and double-precision floatingpoint numbers, with machine-dependent precision.

float(n) Floating point number, with user-specified precision of atleast n digits.

Inf4Oec10, SL03 7/52 M. Bohlen, ifi@uzh

Create Table Construct

◮ An SQL table is defined using the create table command:

create table r(A1D1,A2D2, . . . ,AnDn,

(integrity-constraint1),. . . ,(integrity-constraintk))

◮ r is the name of the table◮ each Ai is a column name in the schema of table◮ Di is the data type of values in the domain of column Ai

◮ Example:

create table branch(BranchName char(15) not null,branch city char(30),assets integer)

Inf4Oec10, SL03 8/52 M. Bohlen, ifi@uzh

Integrity Constraints in Create Table

◮ not null

◮ primary key (A1, . . . ,An)

Example: Declare BranchName as the primary key for branch

create table branch(BranchName char(15),BranchCity char(30),Assets integer,primary key (BranchName))

In SQL a primary key declaration on a column automatically ensuresnot null.

Inf4Oec10, SL03 9/52 M. Bohlen, ifi@uzh

Drop and Alter Table Constructs

◮ The drop table command deletes all information about the droppedtable from the database.

◮ The alter table command is used to add columns to an existingtable:

alter table r add A D

where A is the name of the column to be added to table r and D isthe domain of A.

◮ All tuples in the table are assigned null as the value for the newcolumn.

◮ The alter table command can also be used to drop columns of atable:

alter table r drop A

where A is the name of an column of table r◮ Dropping of columns not supported by many databases

Inf4Oec10, SL03 10/52 M. Bohlen, ifi@uzh

Expressions and Predicates

◮ Powerful expressions and predicates make computer languages usefuland convenient.

◮ Database vendors compete on the set of expressions and predicatesthey offer (functionality as well as speed).

◮ In databases the efficient evaluation of predicates is a major concern.

◮ Consider a table with 1 billion tuples and the following predicates:◮ LastName = ’Miller’◮ LastName like ’%mann’◮ LastName like ’Ester%’

◮ That is one of the reasons why additions of (user defined) functionsand predicates to DBMS has been limited.

◮ We show some SQL expressions and predicates to give a rough ideaof common database functionality.

Inf4Oec10, SL03 11/52 M. Bohlen, ifi@uzh

Structure of SQL Queries/1

◮ SQL is based on relations and relational operations with certainmodifications and enhancements.

◮ It is used very heavily in the real world.

◮ Note that SQL is much more than simple select-from-where queriessuch as the following:

select *from Employeewhere LName = ’Bohr’

◮ Many people◮ Do not understand the concepts of SQL◮ Do not really understand how to work with a declarative language

and sets (this requires some practice and getting used to)◮ Underestimate SQL

Inf4Oec10, SL03 12/52 M. Bohlen, ifi@uzh

Structure of SQL Queries/2

◮ A typical SQL query has the form:

select clausefrom clausewhere clausegroup clausehaving clause

table

expression

query

specification

union

select clausefrom clausewhere clausegroup clausehaving clause

table

expression

query

specification

query

expression

◮ The result of an SQL query is a (virtual) table.

Inf4Oec10, SL03 13/52 M. Bohlen, ifi@uzh

Conceptual Evaluation of SQL Statements

1. Form the cross product of the tables in the from clause

2. Eliminate tuples that do not satisfy the where clause

3. Group the remaining tuples according to the group clause

4. Eliminate groups that do not satisfy the having clause

5. Evaluate the expressions in the select clause

6. One result tuple is produced for each group

7. Eliminate duplicates if distinct is specified

8. Compute query expressions independently and apply set operations(union, excpet, intersect)

9. Sort all result tuples according to order clause

Inf4Oec10, SL03 14/52 M. Bohlen, ifi@uzh

The from Clause

◮ The from clause lists the tables involved in the query◮ Corresponds to the Cartesian product operation of the relational

algebra.

◮ Cartesian product borrower × loan

from borrower , loan

◮ Customer names and loan numbers (all combinations):

from borrower as T , loan as S

◮ Renaming can become necessary if the same table is used multipletimes in the from clause.

Inf4Oec10, SL03 15/52 M. Bohlen, ifi@uzh

The where Clause

◮ The where clause specifies conditions that the result tuples mustsatisfy.

◮ The where clause takes the virtual table produced by the fromclause and filters out those rows that do not satisfy the condition.

◮ Example: loan number of loans from the Perryridge branch withloan amounts greater than $1200.

from loan

where BraName = ‘Perryridge’ and Amount > 1200

LoanNum BraName Amount

L-260 Perryridge 1700

◮ The where clause corresponds to the selection predicate.

◮ In SQL predicates can be combined using the logical connectivesand, or, and not.

◮ The where clause can be used to specify join and selectionconditions.

Inf4Oec10, SL03 16/52 M. Bohlen, ifi@uzh

The group Clause◮ The group clause takes the table produced by the where clause and

returns a grouped table.◮ The group clause groups multiple tuples together. Conceptually,

grouping yields multiple tables.◮ Example: Accounts grouped by branch.

from account

group by BrName

account

AccNr BrName Balance

A-101 Downtown 500

A-215 Perryridge 700

A-102 Perryridge 400

A-305 Perryridge 350

A-222 Perryridge 700

A-201 Brighton 900

A-217 Brighton 750

Inf4Oec10, SL03 17/52 M. Bohlen, ifi@uzh

The having Clause/1

◮ The having clause takes a grouped table as input and returns agrouped table.

◮ The having condition is applied to each group.

◮ Only groups that fulfill the condition are returned.

◮ The having clause never returns individual tuples of a group.

◮ The having condition may include grouping columns or aggregatedcolumns.

Inf4Oec10, SL03 18/52 M. Bohlen, ifi@uzh

The having Clause/2

◮ Consider branches with more than one account only:

from account

group by BrName

having count(AccNr) > 1

◮ This having clause returns all groups with more than one tuple:

account

AccNr BrName Balance

A-215 Perryridge 700

A-102 Perryridge 400

A-305 Perryridge 350

A-222 Perryridge 700

A-201 Brighton 900

A-217 Brighton 750

Inf4Oec10, SL03 19/52 M. Bohlen, ifi@uzh

The select Clause/1

◮ The select clause lists the columns that shall be in the result of aquery.

◮ corresponds to the projection operation of the relational algebra

◮ Example: find the names of all branches in the loan table:

select BraName

from loan

◮ In the relational algebra, the query would be:

πBraName(loan)

Inf4Oec10, SL03 20/52 M. Bohlen, ifi@uzh

The select Clause/2

◮ SQL allows duplicates in tables as well as in query results.

◮ To force the elimination of duplicates, insert the keyword distinctafter select.

◮ Find the names of all branches in the loan tables, and removeduplicates

select distinct BraName

from loan

◮ A * in the select clause denotes “all columns”

select *from loan

Inf4Oec10, SL03 21/52 M. Bohlen, ifi@uzh

The select Clause/3

◮ In the select clause aggregate functions can be used.◮ avg: average value◮ min: minimum value◮ max: maximum value◮ sum: sum of values◮ count: number of values

◮ The aggregate functions operate on multiple rows. They process allrows of a group and compute an aggregated value for that group.

◮ Note: Columns in select clause outside of aggregate functions mustappear in group by list

Inf4Oec10, SL03 22/52 M. Bohlen, ifi@uzh

The select Clause/4

◮ Find the average account balance at the Perryridge branch.

select avg(Balance)from account

where BrName = ‘Perryridge’

◮ Find the number of tuples in the customer table.

select count(∗)from customer

◮ Find the number of accounts per branch.

select count(AccNr), BrNamefrom account

group by BrName

Inf4Oec10, SL03 23/52 M. Bohlen, ifi@uzh

Checking...

1. Identify problem of the following SQL statements. Propose a fix.

Determine for each branch where the largest balance is at least 500the largest balance.

select max(Balance), BrNamefrom accountwhere max(Balance) > 500group by BrName

The where clause does not permit aggregates (it filters tuples)

select max(Balance), BrNamefrom accountgroup by BrNamehaving max(Balance) > 500

Inf4Oec10, SL03 24/52 M. Bohlen, ifi@uzh

Checking...account

AccNr BrName Balance

A-101 Downtown 500

A-215 Perryridge 700

A-102 Perryridge 400

A-305 Perryridge 350

A-222 Perryridge 700

A-201 Brighton 900

A-217 Brighton 750

2. Identify problem of the followingSQL statements.

Determine for each branch theaccount with the largest balance.

select max(Balance), AccNr, BrNamefrom accountgroup by BrName

In the select clause only aggregates or grouped columns are allowed.The reason for this constraint is that exactly one tuple per groupshall be computed.

The above query must be solved with a subquery.

Inf4Oec10, SL03 25/52 M. Bohlen, ifi@uzh

SQL so far

◮ SQL versus relational algebra:

SQL Algebra

table relation

column attribute

row tuple

query relational algebra expression

◮ A query specification in SQL has the following form:

select clausefrom clause

where clause

group clause

having clause

table

expression

query

specification

Inf4Oec10, SL03 26/52 M. Bohlen, ifi@uzh

Illustration of Evaluation of SQL Statements/1

1. FROM: form the cross product of the tables in the from clause

FROM...

2. WHERE: eliminate tuples that do not satisfy the where clause

...WHERE

3. GROUP BY: group tuples according to the group clause

GROUP BY

Inf4Oec10, SL03 27/52 M. Bohlen, ifi@uzh

Illustration of Evaluation of SQL Statements/2

4. HAVING: eliminate groups that do not satisfy the having clause

HAVING

5. SELECT: evaluate the expressions in the select clause and produceone result tuple for each group

SELECT

Inf4Oec10, SL03 28/52 M. Bohlen, ifi@uzh

Query Expressions/1

◮ The set operations union, intersect, and except operate on tablesand correspond to the relational algebra operations ∪, ∩ , −

◮ Each of the above operations automatically eliminates duplicates; toretain all duplicates use the corresponding multiset versions unionall, intersect all, and except all.

Suppose a tuple occurs m times in r and n times in s, then, itoccurs:

◮ m + n times in r union all s◮ min(m, n) times in r intersect all s◮ max(0,m − n) times in r except all s

Inf4Oec10, SL03 29/52 M. Bohlen, ifi@uzh

Query Expressions/2

◮ Find all customers who have a loan, an account, or both:

(select CuName from depositor)union(select CstName from borrower)

◮ Find all customers who have both a loan and an account:

(select CuName from depositor)intersect(select CstName from borrower)

◮ Find all customers who have an account but no loan:

(select CuName from depositor)except(select CstName from borrower)

Inf4Oec10, SL03 30/52 M. Bohlen, ifi@uzh

Subqueries/1

◮ SQL provides a mechanism for the nesting of subqueries.

◮ A subquery is a query expression that is nested within anotherquery expression.

◮ A common use of subqueries is to perform tests for set membership,set comparisons, and set cardinality.

Inf4Oec10, SL03 31/52 M. Bohlen, ifi@uzh

Subqueries/2

◮ Find all customers who have both an account and a loan at thebank.

select distinct CstName

from borrower

where CstName in (select CuName

from depositor)

◮ Find all customers who have a loan at the bank but do not have anaccount at the bank

select distinct CstName

from borrower

where CstName not in (select CuName

from depositor)

Inf4Oec10, SL03 32/52 M. Bohlen, ifi@uzh

Subqueries/3

◮ Find all customers who have both an account and a loan at thePerryridge branch

select distinct CstName

from borrower , loan

where borrower .LoanNo = loan.LoanNr

and BraName = ‘Perryridge’and (BraName,CstName) in (

select BrName,CuName

from depositor , account

where depositor .AccNr = account.AccNr)

Inf4Oec10, SL03 33/52 M. Bohlen, ifi@uzh

Subqueries/4Comparing sets:

◮ Find all branches that have greater assets than some branch locatedin Brooklyn.

select distinct T .BranchName

from branch as T , branch as S

where T .Assets > S .Assets andS .BranchCity = ‘Brooklyn’

◮ Same query using > some clause

select BranchName

from branch

where Assets > some(select Assetsfrom branch

where BranchCity = ‘Brooklyn’)

Inf4Oec10, SL03 34/52 M. Bohlen, ifi@uzh

Subqueries/5

◮ F <comp> some r ⇔ ∃t ∈ r such that (F <comp> t)Where <comp> can be: <,≤ , >,=, 6=

(5 < some

0

5

6

) = true

(read: 5 < some tuple in the table)

(5 < some0

5) = false

(5 = some0

5) = true

(5 6= some0

5) = true (since 0 6= 5)

(= some) ≡ inHowever, ( 6= some) 6≡ not in

Inf4Oec10, SL03 35/52 M. Bohlen, ifi@uzh

Subqueries/6

◮ Find the names of all branches that have greater assets than allbranches located in Brooklyn.

select BranchName

from branch

where assets > all(select assetsfrom branch

where BranchCity = ‘Brooklyn’)

Inf4Oec10, SL03 36/52 M. Bohlen, ifi@uzh

Subqueries/7

◮ F <comp> all r ⇔ ∃t ∈ r (F <comp> t)

(5 < all

0

5

6

) = false

(5 < all6

10) = true

(5 = all4

5) = false

(5 6= all4

6) = true (since 5 6= 4 and 5 6= 6)

( 6= all) ≡ not inHowever, (= all) 6≡ in

Inf4Oec10, SL03 37/52 M. Bohlen, ifi@uzh

Subqueries/8

◮ The exists construct returns the value true if the argumentsubquery is nonempty.

◮ exists r ⇔ r 6= ∅

◮ not exists r ⇔ r = ∅

◮ The exists (and not exists) subqueries are used frequently in SQL.

◮ Avoid in, all, any, some and use exists instead.

Inf4Oec10, SL03 38/52 M. Bohlen, ifi@uzh

Subqueries/9

◮ Find all customers who have an account at all branches located inBrooklyn.

select distinct S .CuName

from depositor as S

where not exists ((select BranchName

from branch

where BranchCity = ‘Brooklyn’)except(select R .BrName

from depositor as T , account as R

where T .AccNr = R .AccNr andS .CuName = T .CuName))

◮ Note that X − Y = ∅ ⇔ X ⊆ Y

◮ Note: Cannot write this query using = all and its variants

Inf4Oec10, SL03 39/52 M. Bohlen, ifi@uzh

Derived Tables

◮ SQL allows a subquery expression to be used in the from clause.

◮ That is important for orthogonality of a language.

◮ A derived table is defined by a query expression.

◮ Find the average account balance of those branches where theaverage account balance is greater than $1200.

select BranchName,AvgBalance

from (select BrName, avg(Balance)from account

group by account)as BranchAvg(BranchName,AvgBalance)

where AvgBalance > 1200

Inf4Oec10, SL03 40/52 M. Bohlen, ifi@uzh

Duplicates/1

◮ In tables with duplicates, SQL can define how many copies of tuplesappear in the result.

◮ Multiset versions of some of the relational algebra operators - givenmultiset relations r1 and r2:

1. σbθ(r1): If there are c1 copies of tuple t1 in r1, and t1 satisfies

selections σθ, then there are c1 copies of t1 in σbθ(r1).

2. πbA(r1): For each copy of tuple t1 in r1, there is a copy of tuple πA(t1)

in πb

A(r1) where πA(t1) denotes the projection of the single tuple t1.

3. r1 ×b r2: If there are c1 copies of tuple t1 in r1 and r2 copies of tuple

t2 in r2, there are c1 × c2 copies of the tuple t1, t2 in r1 ×b r2

Inf4Oec10, SL03 41/52 M. Bohlen, ifi@uzh

Duplicates/2

◮ Example: Suppose multisets r1(A,B) and r2(C ) are as follows:

r1 = {(1, a) (2, a)} r2 = {(2), (3), (3)}

◮ Then πbB(r1) would be {(a), (a)}, while πb

B(r1)× r2 would be

{(a, 2), (a, 2), (a, 3), (a, 3), (a, 3), (a, 3)}

◮ SQL duplicate semantics:

select A1,A2, . . . ,An

from r1, r2, . . . , rmwhere P

is equivalent to the multiset expression:

πbA1,A2,...,An

(σbP(r1 ×

b r2 ×b. . . ×b rm))

Inf4Oec10, SL03 42/52 M. Bohlen, ifi@uzh

Null Values/1

◮ It is possible for tuples to have a null value, denoted by null, forsome of their columns

◮ null signifies an unknown value or that a value does not exist.

◮ The predicate is null can be used to check for null values.

◮ Example: Find all loan number which appear in the loan relation withnull values for Amount.

select LoanNrfrom loan

where Amount is null

◮ The result of any arithmetic expression involving null is null

◮ Example: 5 + null returns null

◮ However, aggregate functions simply ignore nulls◮ More on next slide

Inf4Oec10, SL03 43/52 M. Bohlen, ifi@uzh

Null Values/2

◮ Any comparison with null returns unknown◮ Example: 5 < null or null <> null or null = null

◮ Three-valued logic using the truth value unknown:◮ OR

(unknown or true) = true,(unknown or false) = unknown

(unknown or unknown) = unknown

◮ AND(true and unknown) = unknown,(false and unknown) = false

(unknown and unknown) = unknown

◮ NOT

(not unknown) = unknown

◮ “P is unknown” evaluates to true if predicate P evaluates tounknown

◮ Result of where clause predicate is treated as false if it evaluates tounknown

Inf4Oec10, SL03 44/52 M. Bohlen, ifi@uzh

Null Values/3

◮ Total all loan amounts

select count(Amount)from loan

◮ Above statement ignores null amounts◮ Result is 0 if there is no non-null amount

◮ All aggregate operations, except count(*), ignore tuples with nullvalues on the aggregated columns.

Inf4Oec10, SL03 45/52 M. Bohlen, ifi@uzh

Ordering the Display of Tuples

◮ List in alphabetic order the names of all customers having a loan inPerryridge branch

select distinct CstName

from borrower , loan

where borrower .LoanNo = loan.LoanNr

and BraName = ‘Perryridge’order by CstName

◮ We may specify desc for descending order or asc for ascendingorder, for each column; ascending order is the default.

◮ Example: order by CustName desc

Inf4Oec10, SL03 46/52 M. Bohlen, ifi@uzh

Deletions/1

◮ Delete all account tuples at the Perryridge branch

delete from accountwhere BrName = ‘Perryridge’

◮ Delete all accounts at every branch located in the city Needham

delete from accountwhere BrName in (select BranchName

from branch

where BranchCity = ‘Needham’)

Inf4Oec10, SL03 47/52 M. Bohlen, ifi@uzh

Insertions/1

◮ Add a new tuple to account

insert into account

values (‘A− 9732′, ‘Perryridge’, 1200)

or equivalently

insert into account(BrName,Balance,AccNr)values (‘Perryridge’, 1200, ‘A− 9732′)

◮ Add a new tuple to account with balance set to null

insert into account

values (‘A− 9732′, ‘Perryridge’, null)

Inf4Oec10, SL03 48/52 M. Bohlen, ifi@uzh

Updates/1

◮ Increase all accounts with balances over $10,000 by 6%, all otheraccounts receive 5%.

◮ Write two update statements:

update account

set Balance = Balance ∗ 1.06where Balance > 10000

update account

set Balance = Balance ∗ 1.05where Balance ≤ 10000

◮ The order is important◮ Can be done better with a single update statement that uses a case

statement.

Inf4Oec10, SL03 49/52 M. Bohlen, ifi@uzh

Summary/1

◮ DDL (data definition language)◮ Used to create, alter, and drop tables.◮ Table definitions include constraints (domain, not null, primary key,

foreign key).◮ Constraints ensure data quality, which in turn gives competitive

advantages to businesses.◮ Enforcing constraints is difficult and requires a focused effort.◮ Data quality must be considered during data acquisition; the

database system must enforce it; it cannot be fixed later.

◮ Expressions and predicates◮ Database systems have been conservative since the efficient

evaluation must be considered.◮ The brute force evaluation of a condition on one billion tuples might

not be good enough.◮ Modern database systems are extensible with user defined functions.

Inf4Oec10, SL03 50/52 M. Bohlen, ifi@uzh

Summary/2

◮ SQL◮ SQL is used very heavily in practice; the intergalactic data speak

[Michael Stonebraker].◮ The building block of the DML are query specifications and query

expressions.◮ SQL is more than simple select-from-where. The set based semantics

of SQL requires some practice.◮ Know the conceptual evaluation/semantics of query expressions.

◮ Form the cross product of the tables in the from clause◮ Eliminate tuples that do not satisfy the where clause◮ Group the remaining tuples according to the group clause◮ Eliminate groups that do not satisfy the having clause◮ Evaluate the expressions in the select clause◮ With aggregation one result tuple is produced for each group◮ Eliminate duplicates if distinct is specified◮ Compute query expressions independently and apply set operations

(union, excpet, intersect)◮ Sort all result tuples of order clause is specified

Inf4Oec10, SL03 51/52 M. Bohlen, ifi@uzh

Summary/3

◮ The difference between set and multisets (or bags) is relevant.

◮ Subqueries are natural and help the understanding; it is possible(and advisable) to only use exists and not exists.

◮ The SQL OLAP extensions (cf. Data Warehouse course) furtherextend SQL to better support report generation (cross tabs, movingaverages, etc).

Inf4Oec10, SL03 52/52 M. Bohlen, ifi@uzh