KEMBAR78
Dbms Module SQL | PDF | Sql | Databases
0% found this document useful (0 votes)
46 views79 pages

Dbms Module SQL

Uploaded by

M Krithika
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
46 views79 pages

Dbms Module SQL

Uploaded by

M Krithika
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 79

Module 1 Part 3:

DATABASE Introduction to Databases


MANAGEMENT Dr. Pushpalatha K
SYSTEM Professor
Sahyadri College of Engineering & Management
Basic SQL
➢ SQL is presently expanded as Structured Query Language.
– SQL was called SEQUEL (Structured English QUEry Language)
– It was designed and implemented at IBM Research as the interface
for an experimental relational database system called SYSTEM R.
➢ SQL is now the standard language for commercial
relational DBMSs.
– The standardization of SQL is a joint effort by the American
National Standards Institute (ANSI) and the International
Standards Organization (ISO),
▪ The first SQL standard is called SQL-86 or SQL1.
Types of SQL Statements
➢ SQL statements are categorized into four different type of
statements
– DML (Data Manipulation Language)
– DDL (Data Definition Language)
– DCL (Data Control Language)
– TCL (Transaction Control Language)
➢ Data Definition Language (DDL)
– Create and modify the structure of database objects in a database.
– These database object may have the Table, view, schema, indexes
➢ Data Manipulation Language (DML)
– allow users to manipulate the data in a database.
– used to retrieve, store, modify, delete, insert and update data in
database
➢ Data Control Language(DCL)
– Used to create privileges to allow users access to, and manipulation
of, the database.
➢ Transaction Control Language (TCL)
– used to manage the transactions in the database.
– These are used to manage the changes made by DML statements
CREATE TABLE command
CREATE TABLE base-table-name (colname datatype [column
constraints – NULL/NOT NULL, DEFAUv LT…, UNIQUE,
CHECK…, PRIMARY KEY],
[,colname datetype [column constraints …]]
...
[table constraints – PRIMARY KEY…, FOREIGN KEY…,
UNIQUE…, CHECK…]
[storage specifications]);

➢ Identifiers
– No SQL keywords may be used
– able name must be unique within the database
– For each column, the user must specify a name that is unique within
the table
➢ Datatypes
– Each column must have a datatype specified
– Standards include various numeric types, fixed-length and varying-
length character strings, bit strings, and user-defined types
– Available datatypes vary from DBMS to DBMS
➢ ANSI(American National Standard Institute)-supported
datatypes
– CHARACTER (size)
– { CHAR | NCHAR } (size)
– VARCHAR (size)
– { NUMERIC | DECIMAL | DEC } [ (precision [, scale ]) ]
– { INTEGER | INT | SMALLINT }
– FLOAT [ (size) ]
– DOUBLE PRECISION
– REAL
Attribute Data Types and Domains in SQL
➢ The basic data types available for attributes include
– numeric, character string, bit, string, Boolean, date, and time.
➢ Numeric data types
– Include integer numbers of various sizes (INTEGER or INT, and
SMALLINT or NUMBER [ (precision [, scale ]) ]
– floating-point (real) numbers of various precision (FLOAT or REAL,
and DOUBLE PRECISION).
– Formatted numbers can be declared by using DECIMAL(i, j)—or
DEC(i, j) or NUMERIC(i, j)
▪ where i, the precision, is the total number of decimal digits and j, the
scale, is the number of digits after the decimal point.
▪ The default for scale is zero, and the default for precision is
implementation-defined.
➢ Character-string data types
– Fixed length—CHAR(n) or CHARACTER(n),
▪ where n is the number of characters
– Varying length— VARCHAR(n) or CHAR VARYING(n) or CHARACTER
VARYING(n),
▪ where n is the maximum number of characters.
– When specifying a literal string value, it is placed between single
quotation marks (apostrophes), and it is case sensitive
➢ Bit-string data types
– Fixed length n—BIT(n)
– Varying length— BIT VARYING(n)
▪ where n is the maximum number of bits.
▪ The default for n, the length of a character string or bit string, is 1.
– A variable-length bitstring data type called BINARY LARGE OBJECT or
BLOB is available to specify columns that have large binary values, such
as images.
– As for CLOB, the maximum length of a BLOB can be specified in kilobits
(K), megabits (M), or gigabits (G).
➢ A Boolean data type has the traditional values of TRUE or
FALSE.
➢ The DATE data type has ten positions, and its components
are YEAR, MONTH, and DAY in the form YYYY-MM-DD.
– The TIME data type has at least eight positions, with the
components HOUR, MINUTE, and SECOND in the form HH:MM:SS.
➢ Datetime datatypes
– DATE
▪ contains the datetime fields YEAR, MONTH, DAY, HOUR, MINUTE, and
SECOND
– TIMESTAMP [ (fractional_seconds_precision) ] [ WITH [ LOCAL ] TIME
ZONE]
▪ Includes year, month, day, hour, minute, and seconds.
▪ fractional_seconds_precision must be a number between 0 and 9. (default is 6)
▪ with a time zone displacement value
– INTERVAL YEAR [ (year_precision) ] TO MONTH
▪ Stores a period of time in years and months
▪ year_precision is the number of digits in the year
▪ Accepted values are 0 to 9. The default is 2
– INTERVAL DAY [ (day_precision) ] TO SECOND [
(fractional_seconds_precision) ]
▪ Stores a period of time in days, hours, minutes, and seconds
▪ day_precision must be a number between 0 and 9. (default is 2)
▪ fractional_seconds_precision must be a number between 0 and 9. (default is 6)
Specifying Constraints in SQL

Constraint Description
NOT NULL Specifies that the column cannot contain a null value

UNIQUE Specifies a column or combination of columns whose val


ues must be unique for all rows in the table

PRIMARY KEY Uniquely identifies each row of the table


FOREIGN KEY Establishes and enforces a foreign key relationship betw
een the column and a column of the referenced table

CHECK Specifies a condition that must be true


Inserting Records

INSERT INTO TABLE_NAME (column1, column2,


column3,...columnN) VALUES (value1, value2,
value3,...valueN);
OR
INSERT INTO TABLE_NAME VALUES (value1, value2, value3,
...valueN);
Examples:
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) VALUES (1,
'Ramesh', 32, 'Ahmedabad', 2000.00 );
INSERT INTO CUSTOMERS (ID,NAME, ADDRESS,SALARY, AGE) VALUES (3,
'kaushik, 'Kota', 2000.00 , 23 );
INSERT INTO CUSTOMERS VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );
Inserting using substitution variable ‘&’
INSERT INTO TABLE_NAME (column1, column2, column3,...columnN)
VALUES (&value1, &value2, &value3,...&valueN);
OR
INSERT INTO TABLE_NAME VALUES (&value1, &value2, &value3,
...&valueN);
Examples:
INSERT INTO employees (employee_id, first_name, last_name, salary)
VALUES (&employee_id, '&first_name', '&last_name', &salary);
INSERT INTO employees VALUES (&employee_id, '&first_name',
'&last_name', &salary, &age, ‘&doj’);
SELECT statement

SELECT * | [DISTINCT] column_name[,...]FROM


table_name[,...][WHERE joincondition |
filtercondition[AND | OR joincondition |
filtercondition...]][GROUP BY column_name[,...]] [HAVING
filtercondition [AND | OR joincondition |
filtercondition...]][UNION [ALL] SELECT
command][ORDER BY column_name [ASC | DESC] [, ...]];

Example:
SELECT * FROM CUSTOMERS;
SELECT ID, NAME, SALARY FROM CUSTOMERS;
Comparison Conditions used with WHERE clause
DELETE Statement

➢ DELETE [FROM] table [WHERE condition];


▪ Deletes all the records of table based on the condition
➢ DELETE [FROM] table
– Deletes all the records of table

➢ Example:
– Delete from students where result=‘F’;
DROP, TRUNCATE AND RENAME table commands

➢ DROP TABLE table_name;


– Drops/Deletes the table
➢ TRUNCATE TABLE table_name;
– Deletes all the rows the table permanently
➢ RENAME old_table_name TO new_table_name;
– Renames the table name
Date Functions

TO_CHAR
TO_DATE
TO_NUMBER

Number Functions
Character Functions
Function Purpose
LOWER(column|expression) Converts alpha character values to lowercase
UPPER(column|expression) Converts alpha character values to uppercase
INITCAP(column|expression) Converts alpha character values to uppercase for the first letter of each word; all
other letters in lowercase
CONCAT(column1|expression1,column2 | Concatenates the first character value to the second character value; equivalent
expression2) to concatenation operator (||)
SUBSTR(column|expression,m[,n]) Returns specified characters from character value starting at character position m
, n characters long
LENGTH(column|expression) Returns the number of characters in the expression
INSTR(column|expression, ’string’, [,m], [ Returns the numeric position of a named string.
n] ) m is the starting position to search, n is the occurrence of the string. Default
values of m and n are 1
LPAD(column|expression, n,'string') Pads the character value right-justified to a total width of n character positions
RPAD(column|expression, n,'string') Pads the character value left-justified to a total width of n character positions
TRIM(leading|trailing|both,trim_character Enables you to trim heading or trailing characters (or both) from a character
FROM trim_source) string.
If trim_character or trim_source is a character literal, it must be enclose in single
quotation marks.
REPLACE(text,search_string,replacement_ Searches a text expression for a character string and, if found, replaces it with a
string) specified replacement string
Number Functions
Function Purpose
ROUND(column|expression, n) Rounds the column, expression, or value to n
decimal places
if n is omitted, no decimal places
TRUNC(column|expression, n) Truncates the column, expression, or value to
n decimal places if n is omitted, n defaults to
zero
MOD(m,n) Returns the remainder of m divided by n
Working with Dates
➢ The Oracle database stores dates in an internal numeric
format: century, year, month, day, hours, minutes, and
seconds.
➢ The default date display format is DD-MON-RR
➢ Valid Oracle dates are between January 1, 4712 B.C., and
December 31, 9999 A.D.
➢ SYSDATE is a function that returns the current database
server date and time.
Operation Result Description
date + number Date Adds a number of days to a date
date - number Date Subtracts a number of days to a date
Date-date Number of days Subtracts one date from another
date + number/24 Date Adds a number of hours to a date
Date Functions

Function Result

MONTHS_BETWEEN(da Number of months between two dates


te1, date2) YYYY/YY YEAR
ADD_MONTHS(date, n) Add n calendar months to date MONTH/MON/MM MONTH
WW/W WEEK
NEXT_DAY(date, 'char') Next day of the date specified
The value of char may be a number representing a DDD/DD/DAY/DY/D DAY
day
or a character string. HH/HH24/HH12 HOUR

LAST_DAY(date) Last day of the month MI MINUTE


SS SECONDS
ROUND(date[,'fmt']) Returns date rounded to the unit that is specified by
AM/PM AM/PM
the
format model fmt
If the format model fmt is omitted, date is rounded to
the nearest day
TRUNC(date[,'fmt']) Returns date with the time portion of the day
truncated to the unit that is specified by the format
model fmt.
If the format model fmt is omitted, date is truncated
to the nearest day.
• Elements of the Date Format Model Time Formats

• Specifying Suffixes to Influence Number Display


➢ Eg:
– SELECT last_name, TO_CHAR(hire_date, ‘DD Month YYYY') AS
HIREDATE FROM employees;
– SELECT last_name, TO_CHAR(hire_date, ‘Ddspth "of" Month YYYY
fmHH:MI:SS AM') HIREDATE FROM employees;
– SELECT TO_CHAR(salary, '$99,999.00') SALARY FROM employees
WHERE last_name = 'Ernst';
– SELECT last_name, hire_date FROM employees WHERE hire_date =
TO_DATE('May 24, 1999', 'Month DD, YYYY');
Multirow or Group Functions
Function Description

AVG([DISTINCT|ALL]n) Average value of n, ignoring null values

COUNT({*|[DISTINCT|ALL]expr Number of rows, where expr evaluates to something


}) other than null
MAX([DISTINCT|ALL]expr) Maximum value of expr, ignoring null values

MIN([DISTINCT|ALL]expr) Minimum value of expr, ignoring null values

STDDEV([DISTINCT|ALL]x) Standard deviation of n, ignoring null values

SUM([DISTINCT|ALL]n) Sum values of n, ignoring null values

VARIANCE([DISTINCT|ALL]x) Variance of n, ignoring null values


Alter Command
➢ ALTER TABLE command is used to:
– Add a new column
– Modify an existing column
– Define a default value for the new column
– Drop a column
➢ ALTER TABLE table_name ADD | MODIFY (column_name column_type[,...]);
➢ ALTER TABLE table_name DROP (column_name[,...]);
➢ ALTER TABLE table_name RENAME COLUMN old_column_name TO
new_column_name;
➢ ALTER TABLE table_name ENABLE | DISABLE | DROP CONSTRAINT
constraint_name;
➢ ALTER TABLE table_name ADD CONSTRAINT constraint_name PRIMARY KEY
(column_name, [,…]) | UNIQUE (column_name) | FOREIGN KEY column_name
REFERENCES table_name[(column_name)] | CHECK(expression);
DROP, TRUNCATE, RENAME and DESCRIBE
➢ DROP TABLE table_name;
– Drops/Deletes the table
➢ TRUNCATE TABLE table_name;
– Deletes all the rows the table permanently
➢ RENAME old_table_name TO new_table_name;
– Renames the table name
➢ DESCRIBE - DESC[RIBE] tablename
– display the structure of a table
– Eg: DESCRIBE employees
Defining a Column Alias

➢ A column alias:
– Renames a column heading
– Is useful with calculations
– Immediately follows the column name
▪ (There can also be the optional AS keyword between the
column name and alias.)
– Requires double quotation marks if it contains spaces or
special characters, or if it is case-sensitive
➢ Eg: SELECT last_name "Name" , job as Designation,
salary*12 "Annual Salary“ FROM employees;
DISTINCT and CONCATENATION OPERATOR (||)
➢ DISTINCT
– Suppreses duplicate tuples (rows)
– Eg: SELECT DISTINCT department_id FROM employees;
➢ Concatenation Operator
– A concatenation operator:
– Links columns or character strings to other columns
– Is represented by two vertical bars (||)
– Creates a resultant column that is a character expression
➢ Eg:
– SELECT last_name||job_id AS "Employees“ FROM employees;
– SELECT last_name ||' is a '||job AS "Employee Details“ FROM
employees;
– SELECT last_name ||': 1 Month salary = '||salary Monthly FROM
employees;
LIKE and NULL…
➢ Using the LIKE Condition
– Use the LIKE condition to perform wildcard searches of valid search
string values.
– Search conditions can contain either literal characters or numbers:
▪ % denotes zero or many characters.
▪ _ denotes one character.
– Eg:
▪ SELECT first_name FROM employees WHERE first_name LIKE 'S%' ;
▪ SELECT last_name FROM employees WHERE last_name LIKE '_o%' ;
➢ Using the NULL Conditions
– Test for nulls with the IS NULL operator.
– Eg:
▪ SELECT last_name, manager_id FROM employees WHERE manager_id
IS NULL ;
ORDER BY ..
➢ Using the ORDER BY Clause
– Sort retrieved rows with the ORDER BY clause:
▪ ASC: ascending order, default
▪ DESC: descending order
– The ORDER BY clause comes last in the SELECT statement
➢ Eg:
– SELECT last_name, job_id, department_id, hire_date FROM
employees ORDER BY hire_date ;
– SELECT last_name, job_id, department_id, hire_date FROM
employees ORDER BY hire_date DESC ;
– SELECT last_name, department_id, salary FROM employees ORDER
BY department_id, salary DESC; - Sorting by multiple columns
– SELECT employee_id, last_name, salary*12 annsal FROM employees
ORDER BY annsal ;
Substitution Variables & and &&
➢ Substitution Variables
– Temporarily store values with single-ampersand (&) and double-
ampersand (&&) substitution
– Used for:
▪ With INSERT
▪ WHERE conditions
▪ ORDER BY clauses
▪ Column expressions
▪ Table names
▪ Entire SELECT statements
➢ Eg:
– SELECT employee_id, last_name, salary, department_id FROM employees
WHERE employee_id = &employee_num ;
– SELECT employee_id, last_name, job_id,&column_name FROM
employees WHERE &condition ORDER BY &order_column ;
– SELECT employee_id, last_name, job_id, &&column_name FROM
employees ORDER BY &column_name ; - reuse the variable value
NVL Function
➢ NVL Function
– Converts a null value to an actual value
– Data types that can be used are date, character, and number.
– Data types must match:
▪ NVL(commission_pct,0)
▪ NVL(hire_date,'01-JAN-97')
▪ NVL(job_id,'No Job Yet')
➢ Eg:
– SELECT last_name, salary, NVL(commission_pct, 0) FROM
employees;
CASE Expression
➢ Applicable when querying, inserting or updating tuples
CASE expr WHEN comparison_expr1 THEN return_expr1
[WHEN comparison_expr2 THEN return_expr2
WHEN comparison_exprn THEN return_exprn
ELSE else_expr]
END
Eg:
➢ Group Functions
– Group functions operate on sets of rows to give one result per group.
▪ AVG
▪ COUNT
▪ MAX
▪ MIN
▪ STDDEV
▪ SUM
▪ VARIANCE

➢ Eg
– SELECT COUNT(*),AVG(salary), MAX(salary), MIN(salary),
SUM(salary) FROM employees WHERE job_id LIKE '%REP%';
– SELECT COUNT(DISTINCT department_id) FROM employees;
GROUP BY Clause
➢ Creating Groups of Data - GROUP BY Clause
– divide rows in a table into smaller groups
Note: All columns in the SELECT list that are not in group functions must
be in the GROUP BY clause
➢ Eg:
– SELECT department_id, AVG(salary) FROM employees GROUP BY
department_id ;
▪ The GROUP BY column does not have to be in the SELECT list.
– SELECT AVG(salary) FROM employees GROUP BY department_id ;
– SELECT department_id, AVG(salary) FROM employees GROUP BY
department_id ORDER BY AVG(salary);
– SELECT department_id dept_id, job_id, SUM(salary) FROM employees
GROUP BY department_id, job_id ; - GROUP BY on Multiple Columns
➢ Restricting Group Results with the HAVING Clause
SELECT column, group_function
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[HAVING group_condition]
[ORDER BY column];
➢ Eg:
– SELECT department_id, MAX(salary) FROM employees GROUP BY
department_id HAVING MAX(salary)>10000 ;
– SELECT job_id, SUM(salary) PAYROLL FROM employees WHERE job_id
NOT LIKE '%REP%‘ GROUP BY job_id HAVING SUM(salary) > 13000
ORDER BY SUM(salary);
– SELECT MAX(AVG(salary)) FROM employees GROUP BY department_id;
Subqueries

➢ Subqueries
– Encloseed in parentheses.
SELECT select_list FROM table main query (outer query)

WHERE expr operator


subquery (inner query)
(SELECT select_list FROM table);
– The subquery (inner query) executes once before the main query
(outer query).
– The result of the subquery is used by the main query
➢ Eg:
– SELECT last_name, salary FROM employees WHERE salary >
(SELECT salary FROM employees WHERE last_name = 'Abel');
Subqueries
➢ Two Types:
– Single-row subquery
▪ Queries that return only one row from the inner SELECT
statement
▪ Uses single row operators - >, =, >=, <, <>, <=
– Multiple -row subquery
▪ Queries that return more than one row from the inner
SELECT statement
▪ Use multiple-row comparison operators - IN, ANY, ALL
Single-Row Subqueries
➢ Display the employees whose job ID is the same as that of employee 141
SELECT last_name, job_id FROM employees WHERE job_id = (SELECT job_id
FROM employees WHERE employee_id = 141);
➢ Display employees whose job ID is the same as that of employee 141 and
whose salary is greater than that of employee 143
SELECT last_name, job_id, salary FROM employees WHERE job_id =
(SELECT job_id FROM employees WHERE employee_id = 141)
AND salary >
(SELECT salary FROM employees WHERE employee_id = 143);
➢ Display the employee last name, job ID, and salary of all employees whose
salary is equal to the minimum salary
SELECT last_name, job_id, salary FROM employees WHERE salary =
(SELECT MIN(salary) FROM employees);
➢ Find the job with the lowest average salary
SELECT job_id, AVG(salary) FROM employees GROUP BY job_id HAVING
AVG(salary) = (SELECT MIN(AVG(salary)) FROM employees GROUP BY job_id);
Multiple-Row Subqueries
➢ Find the employees who earn the same salary as the minimum salary
for each department.
SELECT last_name, salary, department_id FROM employees WHERE salary IN
(SELECT MIN(salary) FROM employees GROUP BY department_id);
➢ displays employees who are not IT programmers and whose salary is
less than that of any IT programmer
SELECT employee_id, last_name, job_id, salary FROM employees WHERE salary <
ANY
(SELECT salary FROM employees WHERE job_id = 'IT_PROG') AND job_id <>
'IT_PROG';
➢ displays employees whose salary is less than the salary of all
employees with a job ID of IT_PROG and whose job is not IT_PROG.
SELECT employee_id, last_name, job_id, salary FROM employees WHERE salary <
ALL
(SELECT salary FROM employees WHERE job_id = 'IT_PROG') AND job_id <>
'IT_PROG';
➢ Update employee 114’s job and salary to match that of
employee 205.
UPDATE employees SET job_id =
(SELECT job_id FROM employees WHERE employee_id = 205),
salary = (SELECT salary FROM employees WHERE employee_id = 205)
WHERE employee_id = 114;
Views
➢ View materialization is am approach that involves physically creating a
temporary or permanent view table when the view is first queried or
created.
➢ view is a virtual table that does not physically exist.
➢ It is stored in Oracle data dictionary and do not store any data.
➢ It can be executed when called.
➢ A view is created by a query joining one or more tables
CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view [(alias[, alias]...)] AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY [CONSTRAINT constraint]];
➢ Eg:
– CREATE VIEW empvu80 AS SELECT employee_id, last_name, salary FROM employees
WHERE department_id = 80;
– CREATE VIEW salvu50 AS SELECT employee_id ID_NUMBER, last_name NAME, salary*12
ANN_SALARY FROM employees WHERE department_id = 50;
JOINS
➢ Obtaining Data from Multiple Tables
– Using Joins –inner join( Equijoin, self join), outer join
➢ Equijoins
SELECT col1, col2, col3... FROM table_name1, table_name2
WHERE table_name1.col2 = table_name2.col1;
– Retrieve the name, address and department name of all employees
▪ SELECT Name, Address,Dname FROM EMPLOYEE, DEPARTMENT WHERE
Dnumber = Dno
– Retrieve the suppplier id, suppplier name and order date all orders
▪ SELECT supplier_id, supplier_name, orders.order_date FROM suppliers, orders
WHERE suppliers.supplier_id = orders.supplier_id;
– Retrieve the name, job and department name of all Sales managers
▪ SELECT last_name, job_id, department_name FROM employees, departments
WHERE employees.department_id = departments.department_id AND job =
'SA_MAN‘ ORDER BY last_name;
➢ Retrieve the name, address and department name of all
employees
– SELECT Fname, Lname, Address FROM (EMPLOYEE JOIN
DEPARTMENT ON Dno = Dnumber)
– SELECT Fname, Lname, Address FROM (EMPLOYEE NATURAL JOIN
DEPARTMENT AS DEPT (Dname, Dno, Mssn, Msdate)))
– SELECT Fname, Lname, Address FROM (EMPLOYEE NATURAL JOIN
DEPARTMENT)
▪ In above query both tables EMPLOYEE and DEPARTMENT have
common attribute to join the tables.
➢ Self Joins
– join of a table to itself.

– Retrieve the employee’s first and last name and the first and last
name of his or her immediate supervisor.
SELECT E.Fname, E.Lname, S.Fname, S.Lname FROM
EMPLOYEE E, EMPLOYEE S WHERE E.Super_ssn = S.Ssn;
Outer Joins
➢ Left outer join
– SELECT supplier_id, supplier_name, orders.order_date FROM suppliers,
orders WHERE suppliers.supplier_id = orders.supplier_id(+);
OR
– SELECT supplier_id, supplier_name, orders.order_date FROM
(suppliers AS S LEFT OUTER JOIN orders O ON S.supplier_id = o.supplier_id(+);

➢ Right outer join


– SELECT supplier_id, supplier_name, orders.order_date FROM suppliers,
orders WHERE suppliers.supplier_id (+)= orders.supplier_id;
➢ Full outer join
– SELECT supplier_id, supplier_name, orders.order_date FROM
(suppliers AS S FULL OUTER JOIN orders O ON S.supplier_id = o.supplier_id(+);
➢ Aliasing
– Use table aliases when same name is used for two (or more)
attributes in different tables or same table is refered twice with
joins
– Retrieve the employee’s first and last name and the first and last
name of his or her immediate supervisor.
SELECT E.Fname, E.Lname, S.Fname, S.Lname FROM
EMPLOYEE E, EMPLOYEE S WHERE E.Super_ssn = S.Ssn;
– Retrieve the suppplier id, suppplier name and order date all
orders
▪ SELECT supplier_id, supplier_name, orders.order_date
FROM suppliers S, orders O WHERE S.supplier_id =
O.supplier_id;
➢ Correlated Subqueries
– Performs when the subquery references a column from a table
referred to in the parent statement
– Correlated subqueries are used for row-by-row processing.
– Each subquery is executed once for every row of the outer query
➢ Nested Subqueries Versus Correlated Subqueries
– Nested Subquery Execution
▪ The inner query executes first and finds a value.
▪ The outer query executes once, using the value from the
inner query.
– Correlated Subquery Execution
▪ Get a candidate row (fetched by the outer query).
▪ Execute the inner query using the value of the candidate row.
▪ Use the values resulting from the inner query to qualify or
disqualify the candidate.
▪ Repeat until no candidate row remains.
➢ Correlated Subqueries
SELECT column1, column2, ... FROM table1 WHERE column1
operator
(SELECT column1, column2 FROM table2 WHERE expr1 =
table1.expr2);

– Find all employees who earn more than the average salary in their
department.
SELECT last_name, salary, department_id FROM employees WHERE
salary > (SELECT AVG(salary) FROM employees WHERE department_id =
employees.department_id);
– Obtain the names of departments that have more than 10 employees
▪ SELECT deptname FROM department d1 WHERE 10 < (SELECT count(*)
FROM employee e WHERE e.dept_id = d1.dept_id)
➢ Using the EXISTS Operator
– The EXISTS operator tests for existence of rows in the
results set of the subquery.
– If a subquery row value is found:
▪ The search does not continue in the inner query
▪ The condition is flagged TRUE
– If a subquery row value is not found:
▪ The condition is flagged FALSE
▪ The search continues in the inner query
➢ Find Employees Who Have At Least One Person Reporting
to Them
SELECT employee_id, last_name, job_id, department_id FROM employees
WHERE EXISTS ( SELECT employee_id FROM employees WHERE
manager_id = employees.employee_id);

➢ Find All Departments That Do Not Have Any Employees


– SELECT department_id, department_name FROM departments d
WHERE NOT EXISTS (SELECT 'X‘ FROM employees WHERE
department_id = d.department_id);
➢ Triggers
– A trigger is special kind of stored procedure that automatically executes
when an event occurs in the database server
– A trigger is triggered automatically when an associated DML statement is
executed
CREATE [OR REPLACE ] TRIGGER trigger_name
{BEFORE | AFTER }
{INSERT [OR] | UPDATE [OR] | DELETE}
[OF col_name]
ON table_name
[FOR EACH ROW]
WHEN (condition)
BEGIN
--- sql statements
END;
create trigger t1 before insert on emp for each row
begin
:new.bonus:=:new.sal*0.1;
end;

create or replace trigger t1 before update on emp for each row


begin
:new.bonus:=:new.sal*0.2;
end;
Comparisons Involving NULL and Three-Valued Logic
➢ Meanings of NULL
– Unknown value
– Unavailable or withheld value
– Not applicable attribute
➢ Each individual NULL value considered to be different from
every other NULL value
➢ SQL uses a three-valued logic:
– TRUE, FALSE, and UNKNOWN (like Maybe)
– NULL = NULL comparison is avoided
➢ SQL allows queries that check whether an attribute value is
NULL
– IS NULL or IS NOT NULL
– Ex: Retrieve the names of all employees who do not have
supervisors
▪ SELECT Fname, Lname FROM EMPLOYEE WHERE Super_ssn IS
NULL;
Logical Connectives in Three-Valued Logic
Nested Queries, Tuples, and Set/Multiset Comparisons

➢ Nested queries are complete select-from-where blocks within


WHERE clause of another query (inner query)
– other query is called the outer query
➢ Comparison operator IN
– Compares a value v with a set (or multiset) of values V
– Evaluates to TRUE if v is one of the elements in V
➢ Ex: Make a list of all project numbers for projects that involve
an employee whose last name is ‘Smith’, either as a worker or
as a manager of the department that controls the project.
➢ Without using IN
SELECT DISTINCT Pnumber FROM PROJECT, DEPARTMENT,
EMPLOYEE WHERE Dnum = Dnumber AND Mgr_ssn = Ssn AND
Lname = ‘Smith’ UNION
( SELECT DISTINCT Pnumber FROM PROJECT, WORKS_ON,
EMPLOYEE WHERE Pnumber = Pno AND Essn = Ssn AND Lname =
‘Smith’ );
➢ Using IN
SELECT DISTINCT Pnumber FROM PROJECT WHERE Pnumber IN (
SELECT Pnumber FROM PROJECT, DEPARTMENT, EMPLOYEE
WHERE Dnum = Dnumber AND Mgr_ssn = Ssn AND Lname = ‘Smith’
) OR
Pnumber IN ( SELECT Pno FROM WORKS_ON, EMPLOYEE WHERE
Essn = Ssn AND Lname = ‘Smith’ );
➢ Use tuples of values IN comparisons
SELECT DISTINCT Essn FROM WORKS_ON WHERE (Pno, Hours) IN (
SELECT Pno, Hours FROM WORKS_ON WHERE Essn = ‘123456789’ );
➢ Other comparison operators to compare a single value v
1. = ANY (or = SOME) operator
▪ Returns TRUE if the value v is equal to some value in the set V and is
hence equivalent to IN
▪ Other operators that can be combined with ANY (or SOME): >, >=, <,
<=, and <>
2. ALL operator
value must exceed (match) all values from nested query
Ex: Return the names of employees whose salary is greater than the salary of
all the employees in department 5:
SELECT Lname, Fname FROM EMPLOYEE WHERE Salary > ALL ( SELECT
Salary FROM EMPLOYEE WHERE Dno = 5 );
Correlated Nested Queries

➢ Whenever a condition in the WHERE clause of a


nested query references some attribute of a
relation declared in the outer query, the two
queries are said to be correlated.
– It is a nested query which evaluated once for each tuple (or
combination of tuples) in the outer query.
➢ Ex: Retrieve the name of each employee who has a dependent
with the same first name and is the same sex as the employee.
SELECT E.Fname, E.Lname FROM EMPLOYEE AS E WHERE
E.Ssn IN ( SELECT D.Essn FROM DEPENDENT AS D WHERE
E.Fname = D.Dependent_name AND E.Sex = D.Sex );
The EXISTS and UNIQUE Functions in SQL for
correlating queries
➢ EXISTS and UNIQUE function
– Check whether the result of a correlated nested query is empty or
not.
– These are Boolean functions that return a TRUE or FALSE result.
➢ EXISTS and NOT EXISTS
– Typically used in conjunction with a correlated nested query
– The EXISTS function is used to check whether the result of a nested
query is empty (contains no tuples) or not.
– The result of EXISTS is TRUE if the nested query result contains at
least one tuple, or FALSE if the nested query result contains no
tuples.
➢ SQL function UNIQUE(Q)
– Returns TRUE if there are no duplicate tuples in the result of query
Q
➢ Retrieve the name of each employee who has a dependent
with the same first name and is the same sex as the employee.
SELECT E.Fname, E.Lname FROM EMPLOYEE AS E WHERE EXISTS (
SELECT * FROM DEPENDENT AS D WHERE E.Ssn = D.Essn AND
E.Sex = D.Sex AND E.Fname = D.Dependent_name);
➢ Retrieve the names of employees who have no dependents.
SELECT Fname, Lname FROM EMPLOYEE WHERE NOT EXISTS (
SELECT * FROM DEPENDENT WHERE Ssn = Essn );
➢ List the names of managers who have at least one dependent
SELECT Fname, Lname FROM EMPLOYEE WHERE EXISTS ( SELECT *
FROM DEPENDENT WHERE Ssn = Essn ) AND EXISTS ( SELECT *
FROM DEPARTMENT WHERE Ssn = Mgr_ssn );
➢ Retrieve the name of each employee who works on all the
projects controlled by department number 5
SELECT Fname, Lname FROM EMPLOYEE WHERE NOT EXISTS ( (
SELECT Pnumber FROM PROJECT WHERE Dnum = 5) EXCEPT (
SELECT Pno FROM WORKS_ON WHERE Ssn = Essn) );
▪ EXCEPT is same as MINUS
OR
SELECT Lname, Fname FROM EMPLOYEE WHERE
NOT EXISTS ( SELECT * FROM WORKS_ON B WHERE ( B.Pno IN (
SELECT Pnumber FROM PROJECT WHERE Dnum = 5 ) AND
NOT EXISTS ( SELECT * FROM WORKS_ON C WHERE C.Essn = Ssn
AND C.Pno = B.Pno )));
➢ Explicit Sets and Renaming in SQL
– AS can be used to rename any attributeor relation
Ex: SELECT E.Lname AS Employee_name, S.Lname AS Supervisor_name
FROM EMPLOYEE AS E, EMPLOYEE AS S WHERE E.Super_ssn = S.Ssn;
➢ Specifying Joined Tables in the FROM Clause of SQL
– A joined table (or joined relation) used to specify a table resulting
from a join operation in the FROM clause of a query.
– JOIN may also be called INNER JOIN
– Ex: Retrieve the name and address of all employees who work for
the ‘Research’ department.
▪ SELECT Fname, Lname, Address FROM (EMPLOYEE JOIN
DEPARTMENT ON Dno = Dnumber) WHERE Dname = ‘Research’;
➢ Different types of join
– NATURAL JOIN
– OUTER JOIN (LEFT, RIGHT, FULL )
➢ NATURAL JOIN on two relations R and S
– No join condition specified
– Is equivalent to an implicit EQUIJOIN condition for each pair of
attributes with same name from R and S
– Rename attributes of one relation so it can be joined with another
using NATURAL JOIN:
Ex: SELECT Fname, Lname, Address FROM (EMPLOYEE NATURAL JOIN
(DEPARTMENT AS DEPT (Dname, Dno, Mssn, Msdate))) WHERE
Dname = ‘Research’;
➢ Note: The above query can also use EMPLOYEE.Dno =
DEPT.Dno as an implicit join condition
INNER and OUTER Joins
➢ INNER JOIN (versus OUTER JOIN)
– Default type of join in a joined table
– Tuple is included in the result only if a matching tuple exists in the
other relation
➢ LEFT OUTER JOIN
– Every tuple in left table must appear in result
– If no matching tuple
▪ Padded with NULL values for attributes of right table
➢ RIGHT OUTER JOIN
– Every tuple in right table must appear in result
– If no matching tuple
▪ Padded with NULL values for attributes of left table
➢ Ex: For each employee, retrieve the employee’s first and last
name and the first and last name of his or her immediate
supervisor.
SELECT E.Lname AS Employee_Name S.Lname AS Supervisor_Name
FROM Employee E LEFT OUTER JOIN EMPLOYEE S ON E.Super_ssn
= S.Ssn)
OR
SELECT E.Lname , S.Lname FROM EMPLOYEE E, EMPLOYEE S
WHERE E.Super_ssn + = S.Ssn
➢ Multiway Join
– Allows join of three or more tables as a single joined table
– EX: For every project located in ‘Stafford’, list the project number,
the controlling department number, and the department manager’s
last name, address, and birth date
SELECT Pnumber, Dnum, Lname, Address, Bdate FROM ((PROJECT JOIN
DEPARTMENT ON Dnum = Dnumber) JOIN EMPLOYEE ON Mgr_ssn =
Ssn) WHERE Plocation = ‘Stafford’;
Aggregate Functions in SQL
➢ Used to summarize information from multiple tuples into
a single-tuple summary
➢ Built-in aggregate functions
– COUNT, SUM, MAX, MIN, and AVG
➢ Grouping
– Create subgroups of tuples before summarizing
➢ To select entire groups, HAVING clause is used
➢ Aggregate functions can be used in the SELECT clause or in
a HAVING clause
➢ Aggregation results can be renamed
SELECT SUM (Salary) AS Total_Sal, MAX (Salary) AS Highest_Sal,
MIN(Salary) AS Lowest_Sal, AVG (Salary) AS Average_Sal FROM
EMPLOYEE
➢ Retrieve the total number of employees in the company
(Q21) and the number of employees in the ‘Research’
department
SELECT COUNT (*) FROM EMPLOYEE, DEPARTMENT WHERE DNO =
DNUMBER AND DNAME = ‘Research’;
➢ Count the number of distinct salary values in the database
SELECT COUNT (DISTINCT Salary) FROM EMPLOYEE;
➢ Retrieve the names of all employees who have two or more
dependents
SELECT Lname, Fname FROM EMPLOYEE WHERE ( SELECT COUNT(*)
FROM DEPENDENT WHERE Ssn = Essn ) > = 2;
➢ NULL values are discarded when aggregate functions are
applied to a particular column
Grouping: The GROUP BY and HAVING Clauses
➢ Partition relation into subsets of tuples
– Based on grouping attribute(s)
– Apply function to each such group independently
➢ GROUP BY clause
– Specifies grouping attributes
➢ Ex: For each department, retrieve the department number,
the number of employees in the department, and their
average salary.
SELECT Dno, COUNT (*), AVG (Salary) FROM EMPLOYEE GROUP BY Dno;
➢ For each project, retrieve the project number, the project
name, and the number of employees who work on that
project.
– SELECT Pnumber, Pname, COUNT (*) FROM PROJECT, WORKS_ON
WHERE Pnumber = Pno GROUP BY Pnumber, Pname;
➢ For each project on which more than two employees work,
retrieve the project number, the project name, and the
number of employees who work on the project.
SELECT Pnumber, Pname, COUNT (*) FROM PROJECT, WORKS_ON
WHERE Pnumber = Pno GROUP BY Pnumber, Pname HAVING
COUNT (*) > 2;
➢ count the total number of employees whose salaries exceed
$40,000 in each department
– SELECT Dno, COUNT (*) FROM EMPLOYEE WHERE Salary>40000
GROUP BY Dno HAVING COUNT (*) > 5;
➢ Note: If the grouping attribute has NULL as a possible
value, then a separate group is created for the null value
➢ For each department that has more than five employees,
retrieve the department number and the number of its
employees who are making more than $40,000.
SELECT Dno, COUNT (*) FROM EMPLOYEE WHERE Salary>40000 AND
Dno IN ( SELECT Dno FROM EMPLOYEE GROUP BY Dno HAVING
COUNT (*) > 5) GROUP BY Dno;
Schema Change Statements in SQL
➢ used to alter a schema by adding or dropping tables,
attributes, constraints, and other schema elements.
➢ The DROP Command
– Used to drop named schema elements, such as tables, domains, or
constraint
➢ Drop behavior options:
– CASCADE and RESTRICT
➢ Example:
– DROP SCHEMA COMPANY CASCADE;
▪ This removes the schema and all its elements including tables,views,
constraints, etc.
– If the RESTRICT option is chosen instead of CASCADE, a table is dropped only if it is
not referenced in any constraints
▪ RESTRICT is the default option
ALTER table command
➢ Alter table actions include:
– Adding or dropping a column (attribute)
– Changing a column definition
– Adding or dropping table constraints
➢ Example:
– ALTER TABLE COMPANY.EMPLOYEE ADD COLUMN Job
VARCHAR(12);
➢ Adding and Dropping Constraints
– ALTER TABLE table_name ADD CONSTRAINT constraint_name
PRIMARY KEY (column_name, [,…]) | UNIQUE (column_name)|
FOREIGN KEY column_name REFERENCES
table_name[(column_name)]| CHECK(expression);
– ALTER TABLE table_name ENABLE | DISABLE | DROP CONSTRAINT
constraint_name;
Dropping Columns, Default Values
➢ To drop a column
– Choose either CASCADE or RESTRICT
– If CASCADE is used , all constraints and views that reference the
column are dropped automatically from the schema, along with the
column
– RESTRICT is possible if no views or constraints refer to it.
▪ ALTER TABLE COMPANY.EMPLOYEE DROP COLUMN Address
CASCADE;
➢ Default values can be dropped and altered :
– ALTER TABLE COMPANY.DEPARTMENT ALTER COLUMN Mgr_ssn
DROP DEFAULT;
– ALTER TABLE COMPANY.DEPARTMENT ALTER COLUMN Mgr_ssn
SET DEFAULT ‘333445555’;

You might also like