我不确定我的查询是否正在做问题的要求。我要么理解错误的问题,要么我对这个问题想要什么感到困惑。但是,从问题中我得到的是找到所有会员的所有memberID,firstname和lastname,这些会员在“Harry Potter”这本书的过去已经签出/或已经签出。不知道我的查询是否正在做它应该做的事
这里有一个问题:
列出MEMBERID,名字,和姓氏谁借当前或过去在冠军“哈利·波特”的库中的所有书籍的成员。如果任何此类书籍具有多份副本,则该成员必须至少借用一本此类书籍的副本。
代码:
CREATE TABLE Book
(bookID INT,
ISBN INT,
title varchar (60),
author varchar (20),
publish_year INT,
category varchar(20),
PRIMARY KEY (bookID));
CREATE TABLE Member
(memberID INT,
lastname varchar (20),
firstname varchar (20),
address varchar(20),
phone_number INT,
limit_ INT,
PRIMARY KEY (memberID));
CREATE TABLE CurrentLoan
(memberID INT ,
bookID INT,
loan_date DATE,
due_date DATE,
PRIMARY KEY (memberID, bookID),
FOREIGN KEY (memberID) REFERENCES Member(memberID),
FOREIGN KEY (bookID) REFERENCES Book(bookID));
CREATE TABLE History
(memberID INT,
bookID INT,
loan_date DATE,
return_date DATE,
PRIMARY KEY (memberID, bookID, loan_date),
FOREIGN KEY (memberID) REFERENCES Member(memberID),
FOREIGN KEY (bookID) REFERENCES Book(bookID));
INSERT INTO Book VALUES (10, 7771452369, 'XML and XQuery', 'Author Le', 2017, 'reference');
INSERT INTO Book VALUES (11, 8881245525, 'XQuery: The XML Query Language', 'Jack Se', 2017, 'reference');
INSERT INTO Book VALUES (12, 9991123546, 'Yellow Bird', 'Jake Red', 2014, 'reference');
INSERT INTO BOOK VALUES (13, 1212121212, 'The Giving Tree', 'Shel Silverstein', 1964, 'fiction');
INSERT INTO BOOK VALUES (14, 2121212121, 'Gone Fishing', 'Shel Silverstein', 1964, 'reference');
INSERT INTO BOOK VALUES (15, 1313131313, 'The Lazy Dog', 'Jake Red', 2016, 'childrens');
INSERT INTO BOOK VALUES (16, 3131313131, 'The Red Bird', 'Jake Red', 2016, 'childrens');
INSERT INTO BOOK VALUES (17, 1414141414, 'The Very Blue Boy', 'Ben Jen', 2006, 'fiction');
INSERT INTO Book VALUES (18, 1113312336, 'Harry Potter 1', 'J. K. Rowling', 2000, 'fiction');
Insert INTO Book VALUES (19, 1113331142, 'Harry Potter 1', 'J. K. Rowling', 2000, 'fiction');
INSERT INTO Book VALUES (20, 2221257787, 'The Real Harry Potter 2', 'J. K. Rowling', 2009, 'fiction');
INSERT INTO Book VALUES (21, 2221254896, 'The Fake Harry Potter 3', 'J. K. Rowling', 2010, 'fiction');
INSERT INTO Book VALUES (22, 2221254896, 'The Fake Harry Potter 3', 'J. K. Rowling', 2010, 'fiction');
INSERT INTO Member VALUES (001, 'Lee', 'Nancy', 'Brownlea Drive', 1254896325, 10);
INSERT INTO Member VALUES (002, 'Le', 'Ray', '10th Street', 1234561256, 2);
INSERT INTO Member VALUES (003, 'Kan', 'Charlie', '5th Street', 1234567236, 8);
INSERT INTO Member VALUES (004, 'Brown', 'Joe', 'Elm Street', 1234567845, 9);
INSERT INTO Member VALUES (005, 'Smith', 'John', '33 East', 1234567890, 3);
INSERT INTO Member VALUES (006, 'Kope', 'NON', '358 spence', 2145345625, 5);
INSERT INTO CurrentLoan VALUES (001, 10, '13-SEP-17', '14-NOV-17');
INSERT INTO CurrentLoan VALUES (001, 11, '13-SEP-17', '14-NOV-17');
INSERT INTO CurrentLoan VALUES (001, 18, '13-SEP-17', '14-NOV-17');
INSERT INTO CurrentLoan VALUES (001, 19, '13-SEP-17', '14-NOV-17');
INSERT INTO CurrentLoan VALUES (001, 21, '13-SEP-17', '14-NOV-17');
INSERT INTO CurrentLoan VALUES (001, 22, '13-SEP-17', '14-NOV-17');
INSERT INTO CurrentLoan VALUES (002, 11, '14-FEB-17', '12-MAR-17');
INSERT INTO CurrentLoan VALUES (003, 19, '12-OCT-17', '09-NOV-17');
INSERT INTO CurrentLoan VALUES (004, 13, '12-OCT-17', '09-NOV-17');
INSERT INTO CurrentLoan VALUES (004, 17, '12-OCT-17', '09-NOV-17');
INSERT INTO History VALUES (001, 15, '03-JAN-16', '25-MAY-16');
INSERT INTO History VALUES (001, 21, '03-JAN-16', '25-MAY-16');
INSERT INTO History VALUES (002, 21, '03-JAN-16', '25-MAY-16');
INSERT INTO History VALUES (002, 18, '03-JAN-16', '25-MAY-16');
INSERT INTO History VALUES (002, 15, '03-JAN-16', '25-MAY-16');
INSERT INTO History VALUES (002, 10, '03-JAN-16', '25-MAY-16');
INSERT INTO History VALUES (003, 10, '12-FEB-16', '05-MAY-16');
INSERT INTO History VALUES (004, 13, '12-JUN-16', '05-AUG-16');
COMMIT;
查询:
SELECT memberID, firstname, lastname
FROM (SELECT Member.memberID, firstname, lastname
FROM Member, Book, CurrentLoan
WHERE Member.memberID = CurrentLoan.memberID
AND Book.bookID = CurrentLoan.bookID
AND Book.title LIKE '%Harry Potter%')
UNION
SELECT memberID, firstname, lastname
FROM (SELECT Member.memberID, firstname, lastname
FROM Member, Book, History
WHERE Member.memberID = History.memberID
AND Book.bookID = History.bookID
AND Book.title LIKE '%Harry Potter%');
提示:切换到现代的,明确的'JOIN'语法 - 更容易编写(没有错误),更易于阅读,也更容易转换成外,如果需要加入。 – jarlh
如果上述数据是正确的,并且如果任务是查找借用所有* HP书籍的成员,则结果集将是空的,因为没有人借用“The Real Harry Potter 2”。 –
JOIN语法是作为ANSI SQL '92标准的一部分添加的,如“1992年”中的。它已经存在了25年,所以现在是时候开始使用它了。 – Aaron