Presentation is loading. Please wait.

Presentation is loading. Please wait.

Structured Query Language

Similar presentations


Presentation on theme: "Structured Query Language"— Presentation transcript:

1 Structured Query Language
Chapter Three Structured Query Language Part 1 – Create Tables

2 Chapter Objectives Learn basic SQL statements for creating database structures Learn basic SQL SELECT statements and options for processing a single table Learn basic SQL SELECT statements for processing multiple tables with subqueries Learn basic SQL SELECT statements for processing multiple tables with joins Learn SQL statements to add, modify, and delete data

3 Structured Query Language
Acronym: SQL Pronounced as “S-Q-L” Also pronounced as “Sequel” Originally developed by IBM as the SEQUEL language in the 1970s SQL-92 is an ANSI national standard adopted in 1992

4 SQL Defined SQL is not a programming language, but rather a data sub-language SQL is comprised of: A data definition language (DDL) Used to define database structures A data manipulation language (DML) Data definition and updating Data retrieval (Queries) There are other SQL functions not covered in this chapter Concurrency control [See Chapter 6] Transaction control [See Chapter 6]

5 Sample DB details PROJECT (ProjectID, Name, Department, MaxHours)
EMPLOYEE (EmployeeNumber, Name, Phone, Department) ASSIGNMENT (ProjectID, EmployeeNum, HoursWorked)

6

7 Referential Integrity Constraints for Sample DB
ProjectID in ASSIGNMENT must exist in ProjectID in PROJECT EmployeeNum in ASSIGNMENT must exist in EmployeeNumber in EMPLOYEE

8 Business Rules for Sample DB
If a PROJECT row is deleted, then all of the ASSIGNMENT rows that are connected to the delete PROJECT row also will be deleted. If an EMPLOYEE row is deleted and that row is connected to any ASSIGNMENT, the EMPLOYEE row deletion will be disallowed. (It must first be re-assigned to another employee).

9 SQL for Data Definition
The SQL data definition statements include CREATE To create database objects ALTER To modify the structure and/or characteristics of database objects DROP To delete database objects

10 SQL for Data Definition: CREATE
Creating database tables The SQL CREATE TABLE statement CREATE TABLE Employee( EmpID Integer Primary Key, EmpName Char(25) Not Null );

11 SQL for Data Definition: CREATE
In general… CREATE TABLE newtablename ( three-part column description, optional table constraints );

12 SQL for Data Definition: CREATE
Column definition includes: Column Name Column data type Optional constraint: Primary Key, Not Null, Null, Default

13

14

15

16 SQL for Data Definition: CREATE with CONSTRAINT
Creating database tables with PRIMARY KEY constraints The SQL CREATE TABLE statement The SQL CONSTRAINT keyword CREATE TABLE Employee( EmpID Integer Not Null, EmpName Char(25) Not Null CONSTRAINT EmpPK PRIMARY KEY (EmpID) );

17 SQL for Data Definition: CREATE with CONSTRAINT
Creating database tables with composite primary keys using PRIMARY KEY constraints The SQL CREATE TABLE statement The SQL CONSTRAINT keyword CREATE TABLE Emp_Skill ( EmpID Integer Not Null, SkillID Integer Not Null, SkillLevel Integer, CONSTRAINT EmpSkillPK PRIMARY KEY (EmpID, SkillID) );

18

19 SQL for Data Definition: CREATE with CONSTRAINT
Creating database tables using PRIMARY KEY and FOREIGN KEY constraints The SQL CREATE TABLE statement The SQL CONSTRAINT keyword CREATE TABLE Emp_Skill ( EmpID Integer Not Null, SkillID Integer Not Null, SkillLevel Integer, CONSTRAINT EmpSkillPK PRIMARY KEY (EmpID, SkillID), CONSTRAINT EmpFK FOREIGN KEY (EmpID) REFERENCES Employee (EmpID), CONSTRAINT SkillFK FOREIGN KEY (SkillID) REFERENCES Skill (SkillID) );

20 SQL for Data Definition: CREATE with CONSTRAINT
Creating database tables using PRIMARY KEY and FOREIGN KEY constraints The SQL CREATE TABLE statement The SQL CONSTRAINT keyword ON UPDATE CASCADE and ON DELETE CASCADE CREATE TABLE Emp_Skill ( EmpID Integer Not Null, SkillID Integer Not Null, SkillLevel Integer, CONSTRAINT EmpSkillPK PRIMARY KEY (EmpID, SkillID), CONSTRAINT EmpFK FOREIGN KEY (EmpID) REFERENCES Employee (EmpID) ON DELETE CASCADE, CONSTRAINT SkillFK FOREIGN KEY (SkillID) REFERENCES Skill (SkillID) ON UPDATE CASCADE );

21

22 Primary Key Constraint: ALTER
Adding primary key constraints to an existing table Note: ALTER not covered in Chapter 3 The SQL ALTER statement ALTER TABLE Employee ADD CONSTRAINT EmpPK PRIMARY KEY(EmpID);

23 Composite Primary Key Constraints: ALTER
Adding a composite primary key constraint to an existing table The SQL ALTER statement ALTER TABLE Emp_Skill ADD CONSTRAINT EmpSkillPK PRIMARY KEY(EmpID, SkillID);

24 Foreign Key Constraint: ALTER
Adding foreign key constraints to an existing table The SQL ALTER statement ALTER TABLE Employee ADD CONSTRAINT EmpFK FOREIGN KEY (DeptID) REFERENCES Department (DeptID);

25 Defining the Cascade Rules: ALTER
Adding referential integrity rules ON UPDATE CASCADE ON DELETE CASCADE The SQL ALTER statement ALTER TABLE Employee ADD CONSTRAINT EmpFK FOREIGN KEY (DeptID) REFERENCES Department (DeptID) ON DELETE CASCADE;

26 Deleting Database Objects: DROP
To remove unwanted database objects from the database, use the SQL DROP statement Warning… The DROP statement will permanently remove the object and all data DROP TABLE Employee;

27 Removing a Constraint: ALTER & DROP
To change the constraints on existing tables, you may need to remove the existing constraints before adding new constraints ALTER TABLE Employee DROP CONSTRAINT EmpFK;


Download ppt "Structured Query Language"

Similar presentations


Ads by Google