Relational Algebra – Constraints CIS 4301 Lecture Notes Lecture /02/2006
Lecture 15© CIS Spring Dependent and Independent Operations R S = R - (R-S) R thetajoin C S = C (R x S) R nat join S = L ( C (R x S)), L is a list of attributes in R followed by attributes in S which are not also in R C is a condition of the form R.A 1 = S.A 1 AND R.A 2 = S.A 2 AND … R.A n =S.A n, where A 1, A 2, A n are all the attributes in the schemas of both R and S
Lecture 15© CIS Spring Constraints on Relations Convenient way to express a variety of constraints on relational schema, incl. ref. integrity Two ways: Let R, S be expressions of rel. algebra, R = “There are no tuples in the result of R” R S“Every tuple in the result of R must also be in the result of S” SQL programming uses the “equal-to-empty style”
Lecture 15© CIS Spring Referential Integrity Movie (Title,Year,length,filmType, studioName,producerC#) MovieExec(name,address,Cert#,netWorth) Want to express the fact that producerC# of every movie tuple must also appear in the cert# component of some MovieExec tuple (i.e., ref. Integrity constraint) Use rel. algebra producerC# (Movie) cert# (MovieExec) producerC# (Movie) - cert# (MovieExec) =
Lecture 15© CIS Spring Functional Dependency MovieStar(name,address,gender, birthdate) How do we express FD: name address
Lecture 15© CIS Spring Sample Schema for Exercises Student(ID, name, address, GPA, SAT) Campus(location, enrollment, rank) Apply(ID, location, date, major, decision)
Lecture 15© CIS Spring Exercises PROJECT {date,decision} (Apply) Campus x Apply Find Names and addresses of all students with GPA > 3.7 who applied to CS major and were rejected Find the enrollment and rank for each campus to which a student with id=“12345” applied