Download presentation
Presentation is loading. Please wait.
Published byHarvey Chapman Modified over 9 years ago
1
Announcements Read 6.7 – 6.10 for Wednesday Homework 6, due Friday 10/29 Project Step 4, due today Research paper –List of sources - due 10/29
2
ALTER TABLE Command To add a new column ALTER TABLE basetablename ADD COLUMN columnname datatype; Ex. ALTER TABLE Student ADD COLUMN birthdate DATETYPE; –Cannot specify NOT NULL, since existing records have no value for this field To drop a column ALTER TABLE basetablename DROP COLUMN columnname; Ex. ALTER TABLE Student DROP COLUMN major; Change database to allow double majors
3
ALTER TABLE Command To add a constraint ALTER TABLE basetablename ADD CONSTRAINT constraint_defn; To drop a constraint ALTER TABLE basetablename DROP CONSTRAINT constraint_name; Add a constraint that does not allow two classes to be scheduled in the same room
4
Other Changes to Tables Renaming a table: RENAME TABLE old-table-name TO new-table-name; Ex: RENAME TABLE FACULTY TO TEACHERS; Dropping a table: –CASCADE; //remove table and all references to it (ex. in a REFERENCES) –RESTRICT; //remove the table only if there are no references to it elsewhere DROP TABLE basetablename; Ex. DROP TABLE CLASS; Dropping an index: DROP INDEX indexname; Ex. DROP INDEX Student_lastName_firstName_ndx;
5
SQL Database Design Language Lecture 16
6
SQL DML Non-procedural, declarative language Can be interactive, can be embedded in host language, or can be stand-alone programming language (SQL/PSMs) Basic commands SELECT UPDATE INSERT DELETE
7
INSERT Operator INSERT INTOtablename [(colname [,colname]...)] VALUES(constant [,constant]...); Used for inserting new records into database, one at a time Not necessary to name columns if values are supplied for all columns, in proper order To insert null value for a column, specify only the other columns or write null as the value Can specify values for some columns, in any order, as long as values match order
8
UPDATE Operator UPDATEtablename SETcolumnname = expression [columnname = expression]... [WHEREpredicate]; Used for changing values in existing records Can update, zero, one, many, or all records in a table For null value, use SET columnname = NULL can use a sub-query to identify records to be updated
9
Examples Change number of credits Change credits and major Set major to null
10
Examples Change the grade of all students enrolled in CSC201A to ‘A’ Increase the number of credits for all students by 3
11
DELETE Operator DELETE FROMtablename WHEREpredicate; Used for deleting existing records from database Can delete zero, one, many, or all records Operation may not work if referential integrity would be lost Can use a sub-query to target records to be deleted If you delete all records from a table, its structure still remains, and you can insert into it later
12
SELECT Statement SELECT [DISTINCT] col-name [AS newname], [,col-name..]… FROMtable-name [alias] [,table-name]… [WHEREpredicate] [GROUP BY col-name [,col-name]…[HAVING predicate] or [ORDER BY col-name [,col-name]…]; Powerful command – equivalent to relational algebra’s SELECT, PROJECT, JOIN and more… Can be applied to one or more tables or views Can display one or more columns (renaming if desired) Predicate is optional, and may include usual operators and connectives Can put results in order by one or more columns Can also group together records with the same value for column(s) Can also use predefined functions
13
Example – Simple Retrieval with Condition Get names, IDs, and number of credits of all Math majors
14
Example – Use of Asterisk Notation for “all columns” Get all information about CSC Faculty
15
Example – Retrieval without Condition Get the course number of courses in which students are enrolled Eliminate duplicates
16
Example – Use of “ORDERED BY” and “AS” Get names and IDs of all Faculty members, arranged in alphabetical order by name. Call the resulting columns FacultyName and FacultyNumber
17
Example – Use of Multiple Conditions Get names of all math majors who have more than 30 credits standard comparison operators: =, <>,, >= standard logical operators: AND, OR, and NOT
18
Example – Natural Join Find IDS and names of all students taking ART103A
19
Example – Natural Join with Ordering Find stuId and grade of all students taking any course taught by the Faculty member whose facId is F110. Arrange in order by stuId.
20
Example – Natural Join of Three Tables Find course numbers and the names and majors of all students enrolled in the courses taught by Faculty member F110
21
Example – Use of Aliases Get a list of all courses that meet in the same room, with their schedules and room numbers
22
Example – Join without Equality Condition Find all combinations of students and Faculty where the student’s major is different from the Faculty member’s department
23
Examples – Using a subquery with Equality Find the numbers of all the courses taught by Byrne of the math department
24
Example – Subquery Using ‘IN’ Find the names and IDS of all Faculty members who teach a class in Room H221
25
Example – Nest Subqueries Get an alphabetical list of names and IDs of all students in any class taught by F110
26
Example – Using EXISTS Find the names of all students enrolled in CSC201A
27
Example – Query Using NOT EXIST Find the names of all students who are not enrolled in CSC201A
28
Example – Query Using UNION Get IDs of all Faculty who are assigned to the history department or who teach in Room H221
29
Example – Using Functions Find the total number of students enrolled in ART103A COUNTreturns the number of values in the column SUMreturns the sum of the values in the column AVGreturns the mean of the values in the column MAXreturns the largest value in the column MINreturns the smallest value in the column
30
Example – Using Functions Find the number of departments that have Faculty in them. Find the average number of credits student have.
31
Examples – Using Functions Find the student with the largest number of credits.
32
Examples – Using Functions Find the ID of the student(s) with the highest grade in any course Find names and IDs of students who have less than the average number of credits
33
Example – Using an Expression and a String Constant Assuming each course is three credits list, for each student, the number of courses he or she has completed
34
Example – Use of GROUP BY For each course, show the number of students enrolled GROUP BY allows us to put together all records with a single value in the specified field
35
Example – Use of HAVING Find all courses in which fewer than three students are enrolled HAVING is used to determine which groups have a quality, just as WHERE is used with tuples to determine which records have some quality.
36
Example – Use of LIKE Get details of all MTH courses % The percent character stands for any sequence of characters of any length >= 0 _ The underscore character stands for any single character.
37
Example – Use of NULL Find the stuId and classNumber of all students whose grades in that course are missing
38
Example – Inserting multiple records Create and fill a new table that shows each course and the number of students enrolled in it
39
Example – Updating with a Query Change the room to B220 for all courses taught by Tanaka
40
Example – Delete with a subquery Erase all enrollment records for Owen McCarthy
41
Active Databases-Constraints DBMS monitors database to prevent illegal states, using constraints and triggers Constraints –can be specified when table is created, or later –IMMEDIATE MODE: constraint checked when each INSERT, DELETE, UPDATE is performed –DEFERRED MODE: postpones constraint checking to end of transaction – write SET CONSTRAINT name DEFERRED –Can use DISABLE CONSTRAINT name, and later ENABLE CONSTRAINT name
42
Triggers More flexible than constraints Must have three parts: –event, some change made to the database –condition, a logical predicate (can be empty) –action, a procedure done when the event occurs and the condition is true, also called firing the trigger Can be fired before or after insert, update, delete Trigger can access values it needs as :OLD. and :NEW. –prefix :OLD refers to values in a tuple deleted or to the values replaced in an update –prefix :NEW refers to the values in a tuple just inserted or to the new values in an update. Can specify whether trigger fires just once for each triggering statement, or for each row that is changed by the statement
43
Trigger Syntax CREATE OR REPLACE TRIGGER trigger_name [BEFORE/AFTER] [INSERT/UPDATE/DELETE] ON table_name [FOR EACH ROW] [WHEN condition] BEGIN trigger body END; Can disable triggers using ALTER TRIGGER name DISABLE; Later write ALTER TRIGGER name ENABLE; Can drop triggers using DROP TRIGGER name;
44
Trigger for Student Enrolling in a Class CREATE TRIGGER ADDENROLL AFTER INSERT ON RevEnroll FOR EACH ROW BEGIN UPDATE RevClass SET currentEnroll = currentEnroll + 1 WHERE RevClass.classNumber = :NEW.classNumber; END;
45
Trigger for Student Dropping a Class CREATE TRIGGER DROPENROLL AFTER DELETE ON RevEnroll FOR EACH ROW BEGIN UPDATE RevClass SET currentEnroll = currentEnroll – 1 WHERE RevClass.classNumber = :OLD.classNumber; END;
46
Trigger for Student Changing Classes CREATE TRIGGER SWITCHENROLL AFTER UPDATE OF classNumber ON RevEnroll FOR EACH ROW BEGIN UPDATE RevClass SET currentEnroll = currentEnroll + 1 WHERE RevClass.classNumber = :NEW.classNumber; UPDATE RevClass SET currentEnroll = currentEnroll – 1 WHERE RevClass.classNumber = :OLD.classNumber; END;
47
Trigger for Checking for Over- enrollment Before Enrolling Student CREATE TRIGGER ENROLL_REQUEST BEFORE INSERT OR UPDATE OF classNumber ON RevEnroll FOR EACH ROW DECLARE numStu number; maxStu number; BEGIN setmaxEnroll into maxStu fromRevClass whereRevClass.classNumber = :NEW.classNumber; setcurrentEnroll + 1 into numStu fromRevClass whereRevClass.classNumber = :NEW.classNumber; if numStu > maxStu RequestClosedCoursePermission(:NEW.stuId, :NEW.classNumber, RevClass.currentEnroll, RevClass.maxEnroll); end if; END;
48
Example Trigger Prevent students from enrolling in two classes that meet at the same time
49
Ending Transactions COMMIT makes permanent changes in the current transaction ROLLBACK undoes changes made by the current transaction
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.