База данных АВТОРЫ-КНИГИ-ИЗДАТЕЛЬСТВА (AUTHORS-BOOKS-PUBLISHERS) состоит из следующих таблиц:
AUTHORS
AUTHOR_ID : INTEGER
AUTHOR_NAME : VARCHAR (20)
AUTHOR_BDATE : DATE
AUTHOR_ADDRESS : VARCHAR (40)
AUTHOR_PICTURE : BLOB
AUTHORS-BOOKS
ISBN : VARCHAR (20)
AUTHOR_ID : INTEGER
BOOKS
ISBN : VARCHAR (20)
TITLE : VARCHAR (30)
PUB_ID : INTEGER
DATE_OF_AGREEMENT : DATE
AGREEMENT_DURAT : INTERVAL
DATE_OF_PUB : DATE
PRICE : MONEY
NUMBER_OF_PAGES : SMALLINT
COVER_PICTURE : BLOB
DESCR : CLOB
PUBLISHERS
PUB_ID : INTEGER
PUB_NAME : VARCHAR (20)
PUB_ADDRESS : VARCHAR (40)
Автор уникально идентифицируется своим идентификатором AUTHOR_ID. Уникальным идентификатором книги является ISBN (как выглядит ISBN, можно посмотреть в выходных данных любой книги). Издательство идентифицируется уникальным идентификатором PUB_ID. В таблицах AUTHORS, BOOKS и PUBLISHERS столбцы AUTHOR_ID, ISBN и PUB_ID соответственно являются первичными ключами. В таблице AUTHORS-BOOKS столбцы AUTHOR_ID и ISBN являются внешними ключами, ссылающимися на первичные ключи таблиц AUTHORS и BOOKS соответственно. В таблице BOOKS столбец PUB_ID является внешним ключом, ссылающимся на первичный ключ таблицы PUBLISHERS.
У каждой книги могут быть один или несколько авторов. Допускается, что авторы книги временно неизвестны. В таблице авторов могут содержаться данные только об авторах книг, описываемых в таблице BOOKS. Каждая книга может быть издана только одним издательством, но для некоторых книг издательство может быть временно неизвестно. Столбец DATE_OF_AGREEMENT содержит дату заключения договора на написание книги между автором и издательством. Столбец AGREEMENT_DURAT содержит временной интервал, в течение которого действует договор. Столбец DATE_OF_PUB содержит даты публикации книг.
Требуется сформулировать запрос "Найти имена авторов, издавших более 10 книг, включая разные издания книги с одним и тем же названием". Какие из приведенных ниже формулировок являются правильными? (несколько) 2/3-
SELECT AUTHOR_NAME
FROM AUTHORS
WHERE (SELECT COUNT (*)
FROM AUTHORS-BOOKS, BOOKS
WHERE AUTHORS.AUTHOR_ID =
AUTHORS-BOOKS.AUTHOR_ID
AND AUTHORS-BOOKS.ISBN =
BOOKS.ISBN) > 10;
SELECT AUTHOR_NAME
FROM AUTHORS
WHERE (SELECT COUNT (*)
FROM AUTHORS-BOOKS
WHERE AUTHORS.AUTHOR_ID =
AUTHORS-BOOKS.AUTHOR_ID) > 10;
SELECT DISTINCT AUTHOR_NAME
FROM AUTHORS, AUTHORS-BOOKS
WHERE AUTHORS.AUTHOR_ID =
AUTHORS-BOOKS.AUTHOR_ID
AND COUNT (ISBN) > 10;
Требуется сформулировать запрос “Найти имена авторов, в название книг которых входит название издательства, в котором издавалась соответствующая книга”. Какие из приведенных ниже формулировок являются правильными?
SELECT DISTINCT AUTHOR_NAME
FROM AUTHORS, AUTHORS-BOOKS,
BOOKS, PUBLISHERS
WHERE AUTHORS.AUTHOR_ID =
AUTHORS-BOOKS.AUTHOR_ID
AND AUTHORS-BOOKS.ISBN = BOOKS.ISBN
AND BOOKS.PUB_ID = PUBLISHERS.PUB_ID
AND BOOKS.TITLE LIKE ‘%’ ||
PUBLISHERS.PUB_NAME || ‘%’; +
SELECT AUTHOR_NAME
FROM AUTHORS, AUTHORS-BOOKS,
BOOKS, PUBLISHERS
WHERE AUTHORS.AUTHOR_ID =
AUTHORS-BOOKS.AUTHOR_ID
AND AUTHORS-BOOKS.ISBN = BOOKS.ISBN
AND BOOKS.PUB_ID =
PUBLISHERS.PUB_ID
AND BOOKS.TITLE LIKE ‘%PUBLISHERS.PUB_NAME%’;
SELECT DISTINCT AUTHOR_NAME
FROM AUTHORS, AUTHORS-BOOKS,
BOOKS, PUBLISHERS
WHERE AUTHORS.AUTHOR_ID =
AUTHORS-BOOKS.AUTHOR_ID
AND AUTHORS-BOOKS.ISBN = BOOKS.ISBN
AND BOOKS.PUB_ID = PUBLISHERS.PUB_ID
AND BOOKS.TITLE LIKE ‘_’ ||
PUBLISHERS.PUB_NAME || ‘_’;
База данных АВТОРЫ-КНИГИ-ИЗДАТЕЛЬСТВА (AUTHORS-BOOKS-PUBLISHERS) состоит из следующих таблиц:
AUTHORS
AUTHOR_ID : INTEGER
AUTHOR_NAME : VARCHAR (20)
AUTHOR_BDATE : DATE
AUTHOR_ADDRESS : VARCHAR (40)
AUTHOR_PICTURE : BLOB
AUTHORS-BOOKS
ISBN : VARCHAR (20)
AUTHOR_ID : INTEGER
BOOKS
ISBN : VARCHAR (20)
TITLE : VARCHAR (30)
PUB_ID : INTEGER
DATE_OF_AGREEMENT : DATE
AGREEMENT_DURAT : INTERVAL
DATE_OF_PUB : DATE
PRICE : MONEY
NUMBER_OF_PAGES : SMALLINT
COVER_PICTURE : BLOB
DESCR : CLOB
PUBLISHERS
PUB_ID : INTEGER
PUB_NAME : VARCHAR (20)
PUB_ADDRESS : VARCHAR (40)
Автор уникально идентифицируется своим идентификатором AUTHOR_ID. Уникальным идентификатором книги является ISBN (как выглядит ISBN, можно посмотреть в выходных данных любой книги). Издательство идентифицируется уникальным идентификатором PUB_ID. В таблицах AUTHORS, BOOKS и PUBLISHERS столбцы AUTHOR_ID, ISBN и PUB_ID соответственно являются первичными ключами. В таблице AUTHORS-BOOKS столбцы AUTHOR_ID и ISBN являются внешними ключами, ссылающимися на первичные ключи таблиц AUTHORS и BOOKS соответственно. В таблице BOOKS столбец PUB_ID является внешним ключом, ссылающимся на первичный ключ таблицы PUBLISHERS.
У каждой книги могут быть один или несколько авторов. Допускается, что авторы книги временно неизвестны. В таблице авторов могут содержаться данные только об авторах книг, описываемых в таблице BOOKS. Каждая книга может быть издана только одним издательством, но для некоторых книг издательство может быть временно неизвестно. Столбец DATE_OF_AGREEMENT содержит дату заключения договора на написание книги между автором и издательством. Столбец AGREEMENT_DURAT содержит временной интервал, в течение которого действует договор. Столбец DATE_OF_PUB содержит даты публикации книг.
Также будем использовать таблицы table1 (a1, a2, c1, c2) и table2 (b1, b2, c1, c2) со следующими телами: