(onum integer NOT NULL UNIQUE,
Amt decimal,
Odate date NOT NULL,
Cnum integer NOT NULL,
Snum integer NOT NULL,
UNIQUE (snum, cnum));
Первое решение предпочтительнее.
CREATE TABLE Salespeople
(snum integer NOT NULL PRIMARY KEY,
Sname char(15) CHECK (sname BETWEEN 'AA' AND 'MZ'),
City char(15),
comm decimal NOT NULL DEFAULT = .10);
CREATE TABLE Orders
(onum integer NOT NULL,
Amt decimal,
Odate date,
Cnum integer NOT NULL,
Snum integer NOT NULL,
CHECK ((cnum > snum) AND (onum > cnum)));
Глава 19
CREATE TABLE Cityorders
(onum integer NOT NULL PRIMARY KEY,
Amt decimal,
Cnum integer,
Snum integer,
City char (15),
FOREIGN KEY (onum, amt, snum)
REFERENCES Orders (onum, amt, snum),
FOREIGN KEY (cnum, city)
REFERENCES Customers (cnum, city) );
CREATE TABLE Orders
(onum integer NOT NULL,
Amt decimal,
Odate date,
Cnum integer NOT NULL,
Snum integer,
Prev integer,
UNIQUE (cnum, onum),
FOREIGN KEY (cnum, prev) REFERENCES Orders (cnum,onum) );9
Глава 20
CREATE VIEW Highratings
AS SELECT *
FROM Customers
WHERE rating =
(SELECT MAX (rating)
FROM Customers);
CREATE VIEW Citynumber
AS SELECT city, COUNT (DISTINCT snum)
FROM Salespeople
GROUP BY city;
CREATE VIEW Nameorders
AS SELECT sname, AVG (amt), SUM (amt)
FROM Salespeople, Orders
WHERE Salespeople.snum = Orders.snum
GROUP BY sname;
CREATE VIEW Multcustomers
AS SELECT *