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
Top Related