资源预览内容
第1页 / 共17页
第2页 / 共17页
第3页 / 共17页
第4页 / 共17页
第5页 / 共17页
第6页 / 共17页
第7页 / 共17页
第8页 / 共17页
第9页 / 共17页
第10页 / 共17页
亲,该文档总共17页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
7.1.1 a) CREATE TABLE Movies ( title CHAR(100), year INT, length INT, genre CHAR(10), studioName CHAR(30), producerC# INT, PRIMARY KEY (title, year), FOREIGN KEY (producerC#) REFERENCES MovieExec(cert#) ); or CREATE TABLE Movies ( title CHAR(100), year INT, length INT, genre CHAR(10), studioName CHAR(30), producerC# INT REFERENCES MovieExec(cert#), PRIMARY KEY (title, year) ); b) CREATE TABLE Movies ( title CHAR(100), year INT, length INT, genre CHAR(10), studioName CHAR(30), producerC# INT REFERENCES MovieExec(cert#) ON DELETE SET NULL ON UPDATE SET NULL, PRIMARY KEY (title, year) ); c) CREATE TABLE Movies ( title CHAR(100), year INT, length INT, genre CHAR(10), studioName CHAR(30), producerC# INT REFERENCES MovieExec(cert#) ON DELETE CASCADE ON UPDATE CASCADE, PRIMARY KEY (title, year) ); d) CREATE TABLE StarsIn ( movieTitle CHAR(100) REFERENCES Movie(title), movieYear INT, starName CHAR(30), PRIMARY KEY (movieTItle, movieYear, starName) ); e) CREATE TABLE StarsIn ( movieTitle CHAR(100) REFERENCES Movie(title) ON DELETE CASCADE, movieYear INT, starName CHAR(30), PRIMARY KEY (movieTItle, movieYear, starName) ); 7.1.2 To declare such a foreign-key constraint between the relations Movie and StarsIn, values of the referencing attributes in Movie should appear in MovieStar as unique values. However, based on primary key declaration in relation StarIn, the uniqueness of movies is guaranteed with movieTitle, movieYear, and starName attributes. Even with title and year as referencing attributes there is no way of referencing unique movie from StarsIn without starName information. Therefore, such a constraint can not be expressed using a foreign-key constraint. 7.1.3 ALTER TABLE Product ADD PRIMARY KEY (model); ALTER TABLE PC ADD FOREIGN KEY (model) REFERENCES Product (model); ALTER TABLE Laptop ADD FOREIGN KEY (model) REFERENCES Product(model); ALTER TABLE Printer ADD FOREIGN KEY (model) REFERENCES Product (model); 7.1.4 ALTER TABLE Classes ADD PRIMARY KEY (class); ALTER TABLE Ships ADD PRIMARY KEY (name); ALTER TABLE Ships ADD FOREIGN KEY (class) REFERENCES Classes (calss); ALTER TABLE Battles ADD PRIMARY KEY (name); ALTER TABLE Outcomes ADD FOREIGN KEY (ship) REFERENCES Ships (name); ALTER TABLE Outcomes ADD FOREIGN KEY (battle) REFERENCES Battles (name); 7.1.5 a) ALTER TABLE Ships ADD FOREIGN KEY (class) REFERENCES Classes (class) ON DELETE SET NULL ON UPDATE SET NULL; In addition to the above declaration, class must be declared the primary key for Classes. b) ALTER TABLE Outcome ADD FOREIGN KEY (battle) REFERENCES Battles (name) ON DELETE SET NULL ON UPDATE SET NULL; c) ALTER TABLE Outcomes ADD FOREIGN KEY (ship) REFERENCES Ships (name) ON DELETE SET NULL ON UPDATE SET NULL; 7.2.1 a) year INT CHECK (year = 1915) b) length INT CHECK (length = 60 AND length = 2.0) ); b) CREATE TABLE Printer ( type VARCHAR(10) CHECK (type IN (laser, ink-jet, bubble-jet) ); c) CREATE TABLE Product ( type VARCHAR(10) CHECK (type IN(pc, laptop, printer) ); d) CREATE TABLE Product ( model CHAR(4) CHECK (model IN (SELECT model FROM PC UNION ALL SELECT model FROM laptop UNION ALL SELECT model FROM printer) ); * note this doesnt check the attribute constraint violation caused by deletions from PC, laptop, or printer 7.2.3 a) CREATE TABLE StarsIn ( starName CHAR(30) CHECK (starName IN (SELECT name FROM MovieStar WHERE YEAR(birthdate) movieYear) ); b) CREATE TABLE Studio ( address CHAR(255) CHECK (address IS UNIQUE) ); c) CREATE TABLE MovieStar ( name CHAR(30) CHECK (name NOT IN (SELECT name FROM MovieExec) ); d) CREATE TABLE Studio ( Name CHAR(30) CHECK (name IN (SELECT studioName FROM Movies) ); e) CREATE TABLE Movies ( CHECK (producerC# NOT IN (SELECT presC# FROM Studio) OR studioName IN (SELECT name FROM Studio WHERE presC# = producerC#) ); 7.2.4 a) CHECK (speed = 2.0 OR price = 15 OR hd = 40 OR price 16) b) CHECK (class NOT IN (SELECT class FROM Classes WHERE numGuns 9 AND bore 14) c) CHECK (ship IN (SELECT s.name FROM Ships s, Battles b, Outcomes o WHERE s.name = o.ship AND b.name = o.battle AND s.launched YEAR(b.date) 7.2.6 The constraint in Example 7.6 does not allow NULL value for gender while the constraint in Example 7.8 allows NULL. 7.3.1 a) ALTER TABLE Movie ADD CONSTRAINT myKey PRIMARY KEY (title, year); b) ALTER TABLE Movie ADD CONSTRAINT producerCheck FOREIGN KEY (producerC#) REFERENCES MovieExec (cert#); c) ALTER TABLE Movie ADD CONSTRAINT lengthCheck CHECK (length = 60 AND length 14); e) ALTER TABLE Ships ADD CONSTRAINT shipDateCheck CHECK (ship IN (SELECT s.name FROM Ships s, Battles b, Outcomes o WHERE s.name = o.ship AND b.name = o.battle AND s.launched = YEAR(b.date) 7.4.1 a) CREATE ASSERTION CHECK (NOT EXISTS ( (SELECT maker FROM Product NATURAL JOIN PC) INTERSECT (SELECT maker FROM Product NATURAL JOIN Laptop) ) ); b) CREATE ASSERTION CHECK (NOT EXISTS (SELECT maker FROM Product NATURAL JOIN PC WHERE speed ALL (SELECT L2.speed F
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号