Professional Documents
Culture Documents
. .
SQL Background
SQL
,
,
(query languages).
,
(4th generation languages).
(
) .
SQL (Structured Query Language, .
)
.
(2)
SQL ,
.
SQL
,
,
,
( ).
(3)
char(n), (string) n .
varchar(n), (string)
n .
int, .
smallint, .
Numeric(p, d), p , d
.
real, .
double precision, .
float(n), n .
date, (, , ).
time, (, , ).
Constraints
- NOT NULL
- UNIQUE
- CHECK
- Primary Key
- Foreign Key
NOT NULL
.
( ,
) not null.
CREATE TABLE Customer
(SID integer NOT NULL,
Last_Name varchar (30) NOT NULL,
First_Name varchar(30));
UNIQUE
UNIQUE .
CREATE TABLE Customer
(SID integer Unique,
Last_Name varchar (30),
First_Name varchar(30));
CHECK
CHECK
.
CREATE TABLE Customer
(SID integer CHECK (SID > 0),
Last_Name varchar (30),
First_Name varchar(30));
SID (>0)
Primary Key
.
.
.
CREATE TABLE
ALTER TABLE
.
MySQL:
CREATE TABLE Customer
(SID integer,
Last_Name varchar(30),
First_Name varchar(30),
PRIMARY KEY (SID));
Primary Key
.
.
CREATE TABLE
ALTER TABLE .
MySQL:
CREATE TABLE Customer
(SID integer,
Last_Name varchar(30),
First_Name varchar(30),
PRIMARY KEY (SID));
ALTER TABLE
MySQL:
ALTER TABLE Customer ADD PRIMARY KEY (SID);
Foreign Key
()
.
.
Customer_SID ORDERS
CUSTOMERS SID.
MySQL:
CREATE TABLE ORDERS
(Order_ID integer,
Order_Date date,
Customer_SID integer,
Amount double,
Primary Key (Order_ID),
Foreign Key (Customer_SID)
references CUSTOMER(SID));
Table CUSTOMER
Column name
Characteristic
SID
Primary Key
Last_Name
First_Name
Table ORDERS
Column name
Characteristic
Order_ID
Primary Key
Order_Date
Customer_SID
Foreign Key
Amount
ALTER TABLE ORDERS
ADD FOREIGN KEY (customer_sid)
REFERENCES CUSTOMER(SID);
Alter Table
ALTER TABLE.
:
- Add a column
- Drop a column
- Change a column name
- Change the data type for a column
.
,
.
SQL ALTER TABLE
ALTER TABLE "table_name"
[alter specification]
Add a column: ADD "column 1" "data type for column 1"
Drop a column: DROP "column 1"
Change a column name: CHANGE "old column name" "new column name"
"data type for new column name"
Change the data type for a column: MODIFY "column 1" "new data type"
Drop - Truncate
Drop Table
DROP TABLE
.
DROP TABLE "table_name"
customer:
DROP TABLE customer.
Truncate Table
TRUNCATE TABLE.
TRUNCATE TABLE "table_name"
Customer:
TRUNCATE TABLE customer
SQL SELECT
SQL SELECT
.
SQL SELECT
:
SELECT 1, 2, 3,
FROM Table1
SQL SELECT
..
* ():
SELECT *
FROM Table1
FROM (
Table1) .
SELECT *
INTO Customers_copy
FROM Customers
SQL DISTINCT
SQL DISTINCT SELECT
.
Customers.
FirstName
LastName
DOB
Phone
John
Smith
John.Smith@yahoo.com
2/4/1968
626 222-2222
Steven
Goldfish
goldfish@fishhere.net
4/4/1974
323 455-4545
Paula
Brown
pb@herowndomain.org
5/24/1978
416 323-3232
James
Smith
jim@supergig.co.uk
20/10/1980
416 323-8888
:
surnames Customers,
SQL DISTINCT:
SELECT DISTINCT LastName FROM Customers ; LastName
Smith
Goldfish
Brown
SQL WHERE
SQL WHERE
SQL SELECT. Customers
FirstName
LastName
DOB
Phone
John
Smith
John.Smith@yahoo.com
2/4/1968
626 222-2222
Steven
Goldfish
goldfish@fishhere.net
4/4/1974
323 455-4545
Paula
Brown
pb@herowndomain.org
5/24/1978
416 323-3232
James
Smith
jim@supergig.co.uk
20/10/1980
416 323-8888
'Smith'. :
SELECT *
FROM Customers
WHERE LastName = 'Smith'
"=" () WHERE:
LastName = 'Smith'
SQL WHERE
SQL WHERE:
<>()
SELECT * FROM Customers WHERE LastName <> 'Smith
> ( )
SELECT *FROM Customers WHERE DOB > '1/1/1970
>= ( )
SELECT * FROM Customers WHERE DOB >= '1/1/1970
< ( )
SELECT *FROM Customers WHERE DOB < '1/1/1970
<= ( )
SELECT * FROM Customers WHERE DOB =< '1/1/1970
LIKE ( )
SELECT * FROM Customers WHERE Phone LIKE '626%
: LIKE
.
Between ( )
SELECT * FROM Customers WHERE DOB BETWEEN '1/1/1970' AND '1/1/1975'
SQL LIKE
SQL WHERE,
. FirstName 'J'.
SELECT *
FROM Customers
WHERE FirstName LIKE 'J%
'416'
:
SELECT *
FROM Customers
WHERE Phone LIKE '416%'
'%' .
'_'.
.
'[]' .
SELECT *
FROM Customers
WHERE Phone LIKE '[4-6]_6%
:
Phone 4 6 ([4-6])
Phone (_)
Phone 6 (6)
Phone column (%)
SQL UPDATE
UPDATE Table1
SET Column1 = Value1, Column2 = Value2
WHERE Some_Column = Some_Value
SQL UPDATE (
)
( WHERE).
SQL UPDATE (
)
( WHERE). WHERE
( WHERE). WHERE
(
WHERE).
SQL DELETE
DELETE FROM Table1
WHERE Some_Column = Some_Value
WHERE ,
.
WHERE
.
SQL ORDER BY
SELECT * FROM Customers
ORDER BY DOB;
ORDER BY DESC
:
SELECT * FROM Customers
ORDER BY DOB, LastName
ORDER BY (. .
)
...
SQL IN
SQL IN
SQL WHERE
SELECT Column1, Column2, Column3,
FROM Table1
WHERE Column1 IN (Value1, Value2, )
SELECT *
FROM EmployeeHours
WHERE Date IN ('5/6/2004', '5/7/2004')
SQL BETWEEN
SQL BETWEEN & AND
.
SELECT Column1, Column2, Column3,
FROM Table1
WHERE Column1 BETWEEN Value1 AND Value2
, .
SQL IN keyword,
, SQL BETWEEN
.
SQL ALIASES
SQL aliases ()
.
SELECT Employee, SUM(Hours) As SumHoursPerEmployee
FROM EmployeeHours
GROUP BY Employee
SQL COUNT
SQL COUNT
.
SELECT COUNT(Column1)
FROM Table1
Customers
SELECT COUNT(LastName) AS NumberOfCustomers
FROM Customers
SQL AVG
SQL AVG
Sales:
.
SELECT AVG(Column1)
FROM Table1
CustomerID
Date
SaleAmount
5/6/2004
$100.22
5/7/2004
$99.95
5/7/2004
$122.95
5/13/2004
$100.00
5/22/2004
$555.55
SQL SUM
SQL SUM
Sales:
SELECT SUM(Column1)
FROM Table1
SELECT SUM(SaleAmount)
FROM Sales
WHERE CustomerID = 3
SaleAmount
$222.95
CustomerID
Date
SaleAmount
5/6/2004
$100.22
5/7/2004
$99.95
5/7/2004
$122.95
5/13/2004
$100.00
5/22/2004
$555.55
SELECT SUM(SaleAmount)
FROM Sales;
SaleAmount
$195.73
SQL GROUP BY
SQL GROUP BY SQL
( ) SUM
(
EmployeeHours
).
Employee
Date
Hours
John Smith
5/6/2004
Allan Babel
5/6/2004
Tina Crown
5/6/2004
John Smith
5/7/2004
Allan Babel
5/7/2004
Tina Crown
5/7/2004
10
John Smith
5/8/2004
To Allan Babel
; Tina Crown
SQL GROUP BY:
Employee
SELECT Employee, SUM (Hours)
John Smith
FROM EmployeeHours
Allan Babel
GROUP BY Employee;
5/8/2004
5/8/2004
SELECT SUM (Hours)
FROM EmployeeHours;
Tina Crown
Hours
25
24
27
SQL HAVING
SQL HAVING
.
SELECT Employee, SUM (Hours)
FROM EmployeeHours
WHERE SUM (Hours) > 24
GROUP BY Employee
SQL JOIN
SQL JOIN
.
.
Customers
Sales
CID
Fname
Lname
DOB
Phone
CID
Date
SaleAmount
John
Smith
John.Smith@yahoo.com
2/4/1968
626 222-2222
5/6/2004
$100.22
Steven
Goldfis
h
goldfish@fishhere.net
4/4/1974
323 455-4545
5/7/2004
$99.95
Paula
Brown
pb@herowndomain.org
5/24/1978
416 323-3232
5/7/2004
$122.95
James
Smith
jim@supergig.co.uk
20/10/1980
416 323-8888
5/13/2004
$100.00
5/22/2004
$555.55
SQL JOIN
( )
.
JOIN WHERE
CustomerID.
FirstName
LastName
SalesPerCustomers
John
Smith
$99.95
Steven
Goldfish
$100.22
Paula
Brown
$222.95
James
Smith
$555.55
SQL JOIN
SELECT Customers.FirstName, Customers.LastName,
SUM(Sales.SaleAmount) AS SalesPerCustomer
FROM Customers JOIN Sales
ON Customers.CustomerID = Sales.CustomerID
GROUP BY Customers.FirstName, Customers.LastName;
SQL JOINS, INNER JOIN OUTER JOIN.
INNER JOIN ("INNER
JOIN" = "JOIN")
To "INNER JOIN"
.
.
Customers
( Sales
CustomerID)
.
SQL JOIN
, ,
OUTER JOIN.
JOIN OUTER JOIN
LEFT OUTER JOIN RIGHT
OUTER JOIN.
LEFT OUTER JOIN LEFT JOIN
FROM
.
SQL JOIN
LEFT JOIN
SELECT Customers.FirstName, Customers.LastName,
SUM(Sales.SaleAmount) AS SalesPerCustomer
FROM Customers LEFT JOIN Sales
ON Customers.CustomerID = Sales.CustomerID
GROUP BY Customers.FirstName, Customers.LastName;
RIGHT OUTER JOIN RIGHT JOIN
LEFT JOIN, RIGHT JOIN
( JOIN
)
SELECT Customers.FirstName, Customers.LastName,
SUM(Sales.SaleAmount) AS SalesPerCustomer
FROM Customers RIGHT JOIN Sales
ON Customers.CustomerID = Sales.CustomerID
GROUP BY Customers.FirstName, Customers.LastName;
????