Получить данные из нескольких таблиц Вопросы
1.Which of the following is not related to a Relational Database?
- Selection
- Projection
- Joining
- Ни один из вышеперечисленных
Answer: D. Опции A, B и C являются основными возможностями реляционной базы данных Oracle.
2.Which of the following methods is used for writing a query with columns from multiple tables?
- SELECT
- ГРУППА ПО
- СОРТИРОВАТЬ ПО
- JOINS
Answer: D. Объединения используются для соединения нескольких таблиц и данных столбцов проекта из нескольких таблиц в Oracle.
3.Which of the following is one of the most common methods to join multiple tables?
- Хеш-соединение
- Equijoin
- Самостоятельное присоединение
- Крестовое соединение
Answer: B. Equijoin - это один из типов объединений, который является наиболее распространенным и простым методом объединения более чем одной таблицы. Equijoins также называют простыми соединениями или внутренними соединениями. Equijoin включает первичный ключ и внешний ключ.
4.Which of following will be used to join rows with other tables if the column values fall in a range defined by inequality operators?
- Equijoin
- Простое присоединение
- Non-equijoin
- Ни один из вышеперечисленных
Answer: C. Equijoins используют операторы равенства для соединения строк, не Equijoins используют операторы неравенства.
5.Which of the following statements is true about Oracle joins?
- Значения NULL включены в набор результатов
- Выбираются только строки с соответствующими условиями
- Выбираются все строки, которые присутствуют в любой из одной таблицы.
- Ни один из вышеперечисленных
Answer: B. Значения NULL и разные записи в общих столбцах соединения исключаются при использовании соединений.
6.Which of the following can be used to join the rows of a table with other rows of the same table?
- Equijoin
- Non-equijoin
- Внешнее соединение
- Self-join
Answer: D. Связь основана на столбцах с логическими и обычно иерархическими отношениями друг с другом.
7.What is true about a cartesian join of two tables in Oracle DB?
- Этого следует избегать, поскольку это дорого и не оптимизировано.
- Он формируется, когда каждая строка из одной таблицы объединяется со всеми строками второй таблицы.
- Оба а и Б
- Ни один из вышеперечисленных
Answer: B. Декартово соединение часто является результатом отсутствующих или неадекватных условий соединения. Это просто перекрестное произведение двух таблиц.
8.Which of the following is one of the basic types of joins in Oracle DB ?
- Внешнее соединение
- Self-join
- Equi-join
- Все вышеперечисленное
Answer: C. Equi-join и non-equijoin - два основных типа соединений в Oracle DB.
9.What is the main condition for using joins between a source table and a target table in Oracle DB for getting a non-cartesian product result?
- Нет условия
- По крайней мере, один из столбцов в обеих таблицах должен быть общим.
- Имена столбцов в обеих объединяемых таблицах должны быть одинаковыми для использования объединений.
- Ни один из вышеперечисленных
Answer: B. Таблицы должны быть связаны через общий столбец, связывающий две сущности. Таблица, соединенная в общем столбце, дает недекартово произведение.
10. Which of the following can be used to fetch rows from multiple tables in a single SQL query?
- SELECT
- WHERE
- FROM
- Equi-joins
Answer: D. Equijoins также называют простыми соединениями или внутренними соединениями. Equijoin включает первичный ключ и внешний ключ.
11.What is true about the source table and the target table in terms of Oracle Joins?
- У них должен быть хотя бы один столбец с одинаковым именем.
- Все столбцы должны иметь одинаковое имя и один и тот же тип данных для объединения двух таблиц.
- Исходная и целевая таблицы не могут быть заменены местами и зависят от позиции
- Ни один из вышеперечисленных
Answer: D. Исходная и целевая таблицы можно поменять местами и не фиксировать на своих позициях. В зависимости от типа соединения, используемого в запросе, результат может отличаться или оставаться таким же.
12.What is true about Natural joins in Oracle DB?
- Имена столбцов исходной и целевой таблиц должны быть идентичными.
- Если имена столбцов исходной и целевой таблиц не совпадают, Oracle неявно выполняет необходимые
- NATURAL JOINS, USING и ON - ключевые слова, связанные с Natural Joins.
- Все вышеперечисленное
Answer: C. Ключевое слово NATURAL JOIN предписывает Oracle идентифицировать столбцы с идентичными именами между исходной и целевой таблицами. В естественных объединениях для объединения таблиц используются все столбцы с соответствующими именами и типами данных. Предложение USING можно использовать для указания только тех столбцов, которые должны использоваться для равного соединения.
13.Assume the tables EMPLOYEES and DEPARTMENT have to be joined using NATURAL JOIN. What is the difference between the following two queries which follow? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT department_id
FROM employees NATURAL JOIN department
WHERE first_name = 'John'
AND last_name = 'Bacon';
SELECT department_id
FROM department NATURAL JOIN employees
WHERE first_name = 'John'
AND last_name = 'Bacon';
- Нет никакой разницы
- Результат в обоих случаях разный.
- Оба запроса выдадут ошибку ORA при выполнении.
- Ни один из вышеперечисленных
Answer: B. Исходную и целевую таблицы можно поменять местами при использовании NATURAL JOIN, что дает реляционно разные наборы результатов.
14.Which of the following options is true regarding the NATURAL JOIN in Oracle DB?
- При использовании NATURAL JOIN упоминание имен всех столбцов из обеих таблиц обязательно.
- NATURAL JOIN можно использовать, только если имена всех столбцов обеих таблиц идентичны.
- Соединение в NATURAL JOIN происходит только тогда, когда пользователь указывает столбцы исходной и целевой таблиц.
- При использовании NATURAL JOINS нет необходимости упоминать столбцы.
Answer: D. При использовании NATURAL JOIN происходит неявное объединение столбцов исходной и целевой таблиц. NATURAL JOIN - это операция JOIN, которая создает для вас предложение неявного соединения на основе общих столбцов в двух соединяемых таблицах. Общие столбцы - это столбцы с одинаковыми именами в обеих таблицах.
15. What is the difference between a NATURAL JOIN and a join with JOIN..ON?
- Нет никакой разницы между обоими
- JOIN..ON объединяет исходную и целевую таблицы в определенных столбцах с тем же именем
- NATURAL JOIN неявно объединяет все совпадающие столбцы из исходной и целевой таблиц
- Ни один из вышеперечисленных
Answer: B, C. Условие соединения для естественного соединения - это, по сути, равное соединение всех столбцов с одинаковым именем. Используйте предложение ON, чтобы указать произвольные условия или указать столбцы для соединения. Условие соединения отделено от других условий поиска. Предложение ON упрощает понимание кода.
16.What is true about the JOIN..ON clause in Oracle DB?
- Это не зависит от одинаковых имен столбцов в исходной и целевой таблицах.
- В этом предложении можно использовать только те столбцы из исходной и целевой таблиц, которые имеют одинаковые имена.
- Это формат NATURAL JOIN
- Все вышеперечисленное
Answer: A, C. Условие соединения для естественного соединения - это, по сути, равное соединение всех столбцов с одинаковым именем. Используйте предложение ON, чтобы указать произвольные условия или указать столбцы для объединения. Условие соединения отделено от других условий поиска. Предложение ON упрощает понимание кода.
17. The database designer has named the key (unique) columns from two tables differently.While joining these tables, which among the following will be the best practice?
- JOIN..ON
- Предложения NATURAL JOIN или JOIN ... ON
- Оба а и Б
- Ни один из вышеперечисленных
Answer: A. Использование NATURAL JOINS в этом случае может привести к неожиданным результатам, так как существует неявный поиск столбцов с одинаковыми именами, которых в этом случае нет.
18.What of the following can be used to fetch non-matching rows along with the matching rows between a source and a target table in Oracle DB?
- EQUI-JOIN
- SELF-JOIN
- ЕСТЕСТВЕННОЕ СОЕДИНЕНИЕ
- OUTER-JOIN
Answer: D. Внешнее соединение создается, когда записи необходимо включить в результаты, не имея соответствующих записей в таблицах соединения. Эти записи сопоставляются с записями NULL, поэтому они включаются в вывод.
19. What are Cartesian Joins also known as in Oracle DB?
- Equi-join
- Anti-join
- Cross-Join
- Ни один из вышеперечисленных
Answer: C. Декартово соединение между двумя таблицами возвращает все возможные комбинации строк из таблиц. Декартово соединение может быть произведено путем исключения операции соединения в запрос или с помощью CROSS JOIN.
20.What will be the result of a NATURAL JOIN between two tables EMPLOYEES and DEPARTMENT as given in the query below? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT * FROM employees NATURAL JOIN department;
- Общий столбец DEPARTMENT_ID с одинаковым именем в обеих таблицах появится дважды в результирующем наборе.
- Все столбцы с одинаковыми именами, соединенные NATURAL JOIN, появятся в результирующем наборе дважды.
- В наборе результатов будет только один столбец для каждой пары столбцов с одинаковыми именами из обеих таблиц.
- Ни один из вышеперечисленных
Answer: C. Ключевые слова NATURAL JOIN не требуют условия для установления связи между двумя таблицами. Однако общий столбец должен существовать. Квалификаторы столбца нельзя использовать с ключевыми словами NATURAL JOIN.
21.What is the difference between a NATURAL JOIN and an EQUI-JOIN in Oracle DB?
- Нет никакой разницы
- Они одинаковы в отношении набора результатов, который получается из обоих
- Оба а и Б
- Ни один из вышеперечисленных
Answer: D. NATURAL JOIN объединяет все столбцы с одинаковыми именами, тогда как EQUI-JOIN требует, чтобы столбцы были явно упомянуты в запросе SQL.
22.What is an INNER JOIN in Oracle DB?
- Соединение, дающее совпадающие записи между двумя таблицами, называется INNER JOIN
- Внутреннее соединение может использовать такие операторы, как <,>, <>
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C. Соединение может быть внутренним соединением, в котором единственные возвращенные записи имеют совпадающую запись во всех таблицах, или внешним соединением, в котором записи могут быть возвращены независимо от того, есть ли соответствующая запись в соединении.
23.What is the difference between a INNER JOIN and an EQUI-JOIN in Oracle DB?
- Они одинаковы с точки зрения синтаксиса и получаемых наборов результатов.
- INNER JOIN - это подмножество EQUI-JOIN
- INNER JOIN может использовать такие операторы, как <,>, <> вместе с "=", тогда как EQUI-JOIN использует только оператор "="
- Все вышеперечисленное
Answer: C. EQUI-JOIN - это тип INNER JOIN, содержащий оператор "=" в условии соединения, тогда как INNER JOIN может содержать как операторы равенства, так и операторы неравенства.
24.What is true about NATURAL JOINS in terms of ANSI SQL: 1999 syntaxes in Oracle DB?
- Используется оператор равенства (=)
- Они дают разные результаты по сравнению с традиционным синтаксисом
- Синтаксис ANSI SQL использует такие слова, как NATURAL JOIN в запросах SQL.
- Ни один из вышеперечисленных.
Answer: C. Синтаксис ANSI SQL отличается от традиционного использования (=) традиционными способами. В синтаксисе ANSI SQL есть такие ключевые слова, как NATURAL JOIN и т. Д., Чтобы различать используемые соединения.
25.What of the following is true with respect to the query given below? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT first_name, salary
FROM employees e, departments d
WHERE e.department_id (+) = d.department_id ;
- Существует внешнее соединение между Department_id из обеих таблиц, которое эквивалентно правому внешнему соединению в ANSI SQL.
- Существует внешнее соединение между Department_id из обеих таблиц, которое эквивалентно левому внешнему соединению в ANSI SQL.
- Он выбирает все записи Department_id из таблицы сотрудников независимо от того, совпадают они или нет.
- Он выбирает все записи Department_id из таблицы отделов независимо от того, совпадают они или нет.
Answer: A, D. Условие e.department_id (+) = d.department_id означает, что оно будет выполнять правое внешнее соединение, и все идентификаторы Department_id из таблицы отделов будут отображаться независимо от того, совпадают они или нет.
26.Which of the following syntax models is used in extensively in the software systems worldwide?
- ANSI SQL: 1999
- И традиционный синтаксис Oracle, и синтаксис ANSI SQL: 1999
- Традиционный синтаксис Oracle
- Все варианты
Answer: C. Синтаксис ANSI SQL: 1999, хотя и не используется так часто, как традиционный синтаксис Oracle, по-прежнему является одним из синтаксисов, которые могут использоваться в Oracle SQL.
27.What of the following is true regarding the Cartesian product in Oracle DB?
- Если «N» - это количество соединенных таблиц, то если нет. объединений - N-1, декартово произведение не выполняется
- Если «N» - это количество соединенных таблиц, то если нет. соединений равно N, выполняется декартово произведение
- Если «N» - это количество соединенных таблиц, то если нет. объединений равно N + 1, выполняется декартово произведение
- Если «N» - это количество соединенных таблиц, то если нет. объединений составляет N-1 или меньше, выполняется декартово произведение.
Answer: A. Декартово соединение между двумя таблицами возвращает все возможные комбинации строк из таблиц. Декартово соединение может быть произведено путем исключения операции соединения в запрос или с помощью CROSS JOIN. В запросе должно быть не менее (N-1) условий соединения, чтобы предотвратить декартово произведение, где N - количество таблиц в запросе.
28.What is the reason of error in the following SQL query? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT first_name, last_name
FROM employees, departments
WHERE department_id (+) = department_id ;
- Для таблиц не используются псевдонимы.
- Слово RIGHT OUTER JOIN здесь не используется, поэтому выдает ошибку.
- Знак (+) должен находиться справа от условия равенства, а не слева.
- Псевдонимы таблиц следует использовать с идентификатором отдела в условии, чтобы исключить неоднозначное именование.
Answer: D. Без псевдонимов таблиц Oracle не может определить происхождение соединяемых столбцов и, следовательно, выдает ошибку неоднозначности при выполнении.
29.Which of the following is used to avoid the ambiguous column problem in Oracle DB?
- ;
- ,
- .
- /
Answer: C. Синтаксис для устранения проблемы неоднозначного столбца: table_alias.column_name
30.Which of the following is the most appropriate about the following query? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT employee_id , first_name, last_name
FROM employees e right outer join department d
On e.department_id = d.department_id ;
- Он дает подробную информацию о тех сотрудниках, которые не работают ни в одном отделе
- Он дает подробную информацию о тех отделах, в которых нет сотрудников
- Он дает подробную информацию обо всех отделах, независимо от того, есть ли у них сотрудники или нет
- Он дает подробную информацию о сотрудниках, которые были приняты на работу в компании «ABC», независимо от отделов.
Answer: C. С помощью метода JOIN для внешних объединений вы можете добавить ключевые слова LEFT, RIGHT или FULL. Левое внешнее соединение включает в себя все записи из таблицы, перечисленной в левой части соединения, даже если в операции соединения не найдено совпадений с другой таблицей. Полное внешнее соединение включает в себя все записи из обеих таблиц, даже если соответствующая запись в другой таблице не найдена.
31.What will be the outcome of the following query? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT *
FROM employees e, department d
WHERE a.department_id = b.department_id ;
- Он предоставит все совпадающие значения из обеих таблиц, которые имеют одинаковый Department_id
- Он предоставит все столбцы из таблицы сотрудников и только первые 100 строк из таблицы отделов.
- Выдает ошибку ORA: недопустимый идентификатор "b.department_id"
- Ни один из вышеперечисленных вариантов
Answer: C. В предложении WHERE должны использоваться те же псевдонимы, что и в предложении FROM.
32.Which of the following is true regarding the USING and ON clauses in table joins? (Choose more than one options if applicable)
- Предложение ON можно использовать для объединения таблиц в столбцах с одним и тем же типом данных, но не обязательно с одинаковым именем.
- Предложения USING и ON используются только для равных и неэквивалентных соединений.
- С предложением ON можно использовать не более одного условия
- Предложение WHERE может быть написано после предложения USING..ON для применения дополнительных условий.
Answer: A, D. Подход JOIN ... USING аналогичен подходу NATURAL JOIN, за исключением того, что общий столбец указан в предложении USING. В предложение USING нельзя включить условие, чтобы указать, как связаны таблицы. Кроме того, квалификаторы столбца нельзя использовать для общего столбца, указанного в предложении USING. Подход JOIN ... ON объединяет таблицы на основе заданного условия. Ключевое слово JOIN в предложении FROM указывает таблицы, которые необходимо объединить, а предложение ON указывает, как эти две таблицы связаны. Этот подход необходимо использовать, если объединяемые таблицы не имеют общего столбца с одинаковым именем в каждой таблице.
33.How many tables can be joined by using the JOINS in Oracle DB?
- 1
- 2
- 255
- Нет ограничений
Answer: D. В настоящее время нет ограничений на количество таблиц, участвующих в объединении.
34. What is true when multiple joins are used in an SQL statement?
- Соединения оцениваются слева направо.
- Соединения оцениваются справа налево.
- В процессе оценки объединений нет приоритета.
- Ни один из вышеперечисленных
Answer: A. Когда в операторе существует несколько соединений, они оцениваются слева направо.
35.What is true with respect to the following query? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SQL> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SELECT bonus, first_name, department_id
FROM bonus b NATURAL JOIN employees e NATURAL JOIN department d;
- Использование NATURAL JOIN для объединения нескольких таблиц является лучшим вариантом и дает точные результаты.
- Вероятность ошибки очень меньше, когда ЕСТЕСТВЕННЫЕ СОЕДИНЕНИЯ используются для объединения нескольких таблиц.
- Предложения USING..JOIN..ON дают более точные результаты, чем NATURAL JOINs при объединении нескольких таблиц.
- Oracle неявно объединяет несколько таблиц, когда используется NATURAL JOIN, и поэтому рекомендуется использовать NATURAL JOINS.
Answer: C. Использование NATURAL JOINS может создавать декартовы произведения строк, а также подвержено ошибкам с ненадежными наборами результатов.
36.What is true about the clauses JOIN..ON in Oracle DB?
- Они не очень надежны по сравнению с NATURAL JOINS при объединении нескольких таблиц.
- Предложение JOIN..ON похоже на предложение WHERE, которое ограничивает строки условиями.
- Дополнительное предложение WHERE является обязательным, когда используется предложение JOIN..ON
- Ни один из вышеперечисленных
Answer: B. Подход JOIN .... ON объединяет таблицы на основе заданного условия. Ключевое слово JOIN в предложении FROM указывает таблицы, которые необходимо объединить, а предложение ON указывает, как эти две таблицы связаны. Этот подход необходимо использовать, если объединяемые таблицы не имеют общего столбца с одинаковым именем в каждой таблице.
Examine the table structures as given. Answer the questions 37 and 38 that follow the query given below:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT e.salary, d.department_id
FROM employees e JOIN department d
On (e.department_id = d.department_id and e.last_name = 'Brandon');
37.What is true with respect to the query given above?
- Выдает ошибку ORA, поскольку обязательного предложения WHERE нет.
- Предложение JOIN..ON не может содержать более одного условия.
- Запрос игнорирует последнее условие и выполняется без ошибки ORA.
- Предложение JOIN..ON может быть записано в форме, приведенной выше, для добавления дополнительных условий.
Answer: D. Предложение WHERE можно опустить, а соответствующие условия можно разместить в самом предложении JOIN..ON, как показано в данном запросе.
38.With respect to the given query, if the JOIN used is replaced with NATURAL JOIN, it throws an error. What is the reason for this error?
- Когда используется NATURAL JOIN, предложение WHERE является обязательным, при отсутствии которого возникает ошибка.
- Предложение ON следует заменить предложением USING.
- Слова NATURAL, JOIN и USING взаимно исключают друг друга в контексте одного и того же предложения соединения.
- Запрос не может объединять предложения NATURAL JOIN и ON (или USING) при соединении.
Answer: C, D.
39.What is true about Non-equijoins in Oracle DB?
- Они присоединяются по ключевому слову NON-EQUI JOIN
- Они используются с помощью предложения JOIN..ON со знаком "="
- Результаты получаются, когда результат упомянутого неравенства оценивается как истинный.
- Ни один из вышеперечисленных
Answer: C. Неравноправные соединения используются с предложением JOIN..ON, но с операторами неравенства.
Examine the structures of the tables EMPLOYEES and DEPARTMENTS as given and answer the questions 40 and 41 that follow.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
40.What will be the outcome of the following query in Oracle DB?
SELECT e.first_name, e.last_name, e.employee_id
FROM employees e JOIN department d
ON (e.salary BETWEEN 1000 AND 10000);
- Это вызовет ошибку ORA, поскольку условие в предложении ON неверно.
- Это вызовет ошибку ORA из-за синтаксической ошибки, поскольку в предложении ON нет знака равенства "=".
- Он будет выполнен успешно и предоставит имя, фамилию и идентификатор сотрудника с указанным условием.
- Неравноправные соединения могут использоваться только для отображения неравенств, но не диапазонов.
Answer: C.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- Результат операции сопоставления неравенства истинен
- Результат операции сопоставления неравенства равен 0
- Результат операции сопоставления неравенства равен 1.
- Результат операции сопоставления неравенства ложный
Answer: A. Соединение по принципу равенства создается, когда данные, объединяющие записи из двух разных таблиц, являются точным совпадением (т. Е. Условие равенства создает связь). В традиционном подходе в качестве оператора сравнения в предложении WHERE используется знак равенства. Подход JOIN может использовать ключевые слова NATURAL JOIN, JOIN ... USING или JOIN ... ON.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- Результат операции сопоставления неравенства истинен
- Результат операции сопоставления неравенства равен 0
- Результат операции сопоставления неравенства равен 1.
- Результат операции сопоставления неравенства ложный
Answer: A. Соединение по принципу равенства создается, когда данные, объединяющие записи из двух разных таблиц, являются точным совпадением (т. Е. Условие равенства создает связь). В традиционном подходе в качестве оператора сравнения в предложении WHERE используется знак равенства. Подход JOIN может использовать ключевые слова NATURAL JOIN, JOIN ... USING или JOIN ... ON.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- Результат операции сопоставления неравенства истинен
- Результат операции сопоставления неравенства равен 0
- Результат операции сопоставления неравенства равен 1.
- Результат операции сопоставления неравенства ложный
Answer: A. Соединение по принципу равенства создается, когда данные, объединяющие записи из двух разных таблиц, являются точным совпадением (т. Е. Условие равенства создает связь). В традиционном подходе в качестве оператора сравнения в предложении WHERE используется знак равенства. Подход JOIN может использовать ключевые слова NATURAL JOIN, JOIN ... USING или JOIN ... ON.
41.You need to find a report which lists the first names and last names of the employees whose salary is greater than 20000 and who are located in any of the departments in the location Geneva. Which of the following queries will give the required results?
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) AND d.loc = upper ('Geneva');
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000);
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >=20000) AND d.loc = 'Geneva';
SELECT e.first_name, e.last_name FROM employees e JOIN departments d ON (e.department_id = d.department_id and e.salary >20000) WHERE d.loc = upper('Geneva');
Answer: A, C.
42.On which of the following conditions is a row returned when an EQUI-JOIN is used to join tables?
- Результат операции сопоставления неравенства истинен
- Результат операции сопоставления неравенства равен 0
- Результат операции сопоставления неравенства равен 1.
- Результат операции сопоставления неравенства ложный
Answer: A. Соединение по принципу равенства создается, когда данные, объединяющие записи из двух разных таблиц, являются точным совпадением (т. Е. Условие равенства создает связь). В традиционном подходе в качестве оператора сравнения в предложении WHERE используется знак равенства. Подход JOIN может использовать ключевые слова NATURAL JOIN, JOIN ... USING или JOIN ... ON.
43.What is true regarding a Self-Join in Oracle DB?
- Для работы соединения требуются только две таблицы
- Столбцы в наборе результатов получены из двух таблиц, но отображаются в одной таблице.
- По сути, исходная таблица дублирует себя для создания целевой таблицы. (Oracle не дублирует таблицы)
- Все вышеперечисленное
Answer: C. Самосоединение используется, когда таблица должна быть присоединена к самой себе для получения необходимых данных. Псевдонимы таблиц требуются в предложении FROM для выполнения самосоединения.
44. With respect to the query and the table structure given below,answer the question.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT *
FROM employees a join employees b
WHERE a.employee_id = b.employee_id ;
Какие из следующих таблиц Oracle рассматривает как исходную и целевую?
- a - источник, b - цель
- b - источник, а - цель
- Oracle не рассматривает ни одну из таблиц как источник или цель
- Ни один из вышеперечисленных
Answer: A. Первое вхождение таблицы сотрудников считается источником, а последующие вхождения - как b, c и так далее.
45.In what scenarios can we use Self-Joins ideally in Oracle DB?
- Когда нам нужно найти повторяющиеся записи в таблице
- Когда нам нужно получить значения NULL из таблицы
- Когда нам нужно отобразить столбец таблицы дважды
- Когда нам нужно отобразить иерархию соответствующих сущностей
Answer: D.
46. What is true about NATURAL JOINS in Oracle DB?
- Объединенные столбцы имеют одинаковое имя, но могут иметь разные типы данных.
- Объединенные столбцы могут иметь один и тот же тип данных, но разные имена.
- Объединенные столбцы должны иметь одинаковые имена и один и тот же тип данных.
- Ни один из вышеперечисленных
Answer: C. Ключевые слова NATURAL JOIN не требуют условия для установления связи между двумя таблицами. Однако должен существовать общий столбец. Квалификаторы столбца не могут использоваться с ключевыми словами NATURAL JOIN.
47.A report has to be extracted which gives the department name, department ID, department city and location ID only for departments 100 and 101. Using NATURAL JOINS, which of the following options will give the required results?
SELECT department_id , department_name ,location, city FROM departments NATURAL JOIN locations WHERE department_id in (100,101);
SELECT department_id , department_name ,location, city FROM locations NATURAL JOIN departments WHERE department_id BETWEEN 100 AND 101;
-
SELECT department_id , department_name ,location, city FROM departments NATURAL JOIN locations WHERE department_id >100 AND department_id >101;
-
SELECT department_id , department_name ,location, city FROM departments NATURAL JOIN locations ;
Answer: A. WHERE может использоваться для дополнительных условий после предложения NATURAL JOIN.
48.In which of the following scenarios shall a USING clause or a NATURAL JOIN clause be used?
- Если имена столбцов в таблицах идентичны, используйте предложение USING.
- Когда типы данных столбцов из таблиц идентичны, используйте NATURAL JOINS
- Если несколько столбцов имеют одинаковые имена, но типы данных не совпадают, можно использовать USING
- NATURAL JOINS следует использовать только тогда, когда имена столбцов и их типы данных совпадают.
Answer: C, D. NATURAL JOINS и USING являются взаимоисключающими, предложение USING следует использовать для сопоставления только одного столбца, если совпадают более одного столбца.
49.Examine the table structures given. What will be the outcome of the following query? (Choose the most appropriate answer)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SELECT e.name, b.bonus
FROM employees e
JOIN bonus b
USING (job_id)
WHERE e.job_id like 'SA%');
- В нем указаны имена и бонусы, полученные всеми сотрудниками какой-либо компании.
- В нем указаны имена и бонусы, полученные всеми сотрудниками на определенной должности в компании.
- Он успешно выполняет присвоение всех имен и бонусов, полученных всеми сотрудниками на всех должностях.
- Выдает ошибку ORA.
Answer: D. Столбцы, используемые в предложении USING, не должны иметь квалификатора (имени таблицы или псевдонима) где-либо в операторе SQL.
50.What is true with respect to INNER JOINS and OUTER JOINS in Oracle DB?
- INNER JOIN возвращает только совпавшие строки
- OUTER JOIN возвращает только строки, которые не совпадают
- OUTER JOIN возвращает строки, которые совпадают, а также те, которые не совпадают
- Ни один из вышеперечисленных
Answer: A, C. Соединение может быть внутренним соединением, в котором единственные возвращенные записи имеют совпадающую запись во всех таблицах, или внешним соединением, в котором записи могут быть возвращены независимо от того, есть ли соответствующая запись в соединении. Внешнее соединение создается, когда записи должны быть включены в результаты, не имея соответствующих записей в таблицах соединения. Эти записи сопоставляются с записями NULL, поэтому они включаются в вывод.
51. What is true regarding FULL OUTER JOIN in Oracle DB?
- Когда оба LEFT OUTER JOIN и RIGHT OUTER JOIN появляются в одном запросе, это называется FULL OUTER JOIN.
- ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ - это то же самое, что и ВНЕШНЕЕ СОЕДИНЕНИЕ.
- Оба а и Б
- Соединение между двумя таблицами, которое возвращает результаты ВНУТРЕННЕГО соединения и ЛЕВОГО и ПРАВОГО ВНЕШНЕГО СОЕДИНЕНИЯ, называется ПОЛНЫМ ВНЕШНИМ СОЕДИНЕНИЕМ.
Answer: D. Полное внешнее соединение включает в себя все записи из обеих таблиц, даже если соответствующая запись в другой таблице не найдена.
Examine the given table structures and answer the questions 52 and 53 that follow.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SQL> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
52.Consider the following query.
SELECT e.job_id , e.first_name, d.department_id
FROM departments D JOIN employees e JOIN BONUS b
USING (job_id );
Этот запрос приводит к ошибке. В чем причина ошибки?
- JOIN..USING может происходить только между двумя таблицами одновременно
- В предложении USING в запросе нет столбца из отдела
- В запросе нет предложения WHERE
- Ни один из вышеперечисленных
Answer: A. Table1 JOIN table2 JOIN table3 не допускается без предложений ON для каждого JOIN
53.You need to display all the non-matching rows from the EMPLOYEES table and the non-matching rows from the DEPARTMENT table without giving a Cartesian product of rows between them. Which of the following queries will give the desired output?
SELECT * FROM employees e, department d WHERE e.department_id = d.department_id ;
SELECT * FROM employees e NATURAL JOIN department d;
SELECT * FROM employees e FULL OUTER JOIN department d ON e.department_id = d.department_id ;
SELECT * FROM employees e JOIN department d ON ( e.department_id > d.department_id ) ;
Answer: C. FULL OUTER JOIN возвращает несовпадающие строки из обеих таблиц. Полное внешнее соединение включает в себя все записи из обеих таблиц, даже если соответствующая запись в другой таблице не найдена.
54.Which of the following ANSI SQL: 1999 join syntax joins are supported by Oracle?
- Декартовы произведения
- Естественные соединения
- Полное ВНЕШНЕЕ присоединение
- Equijoins
Answer: D.
55.Which of the following is not a format for Outer Joins in Oracle DB?
- Right
- Left
- Centre
- Full
Answer: C. За исключением «Center», остальные 3 типа являются типами форматов внешних соединений в Oracle DB. С помощью метода JOIN для внешних объединений вы можете добавить ключевые слова LEFT, RIGHT или FULL.
Examine the given table structures. Answer the questions 56, 57 and 58 that follow by referring to the following query:
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT *
FROM employees e NATURAL JOIN department d;
56.You need to find the results obtained by the above query only for the departments 100 and 101. Which of the following clauses should be added / modified to the above query?
- ON (e.department_id = d.department_id) следует добавить
- ИСПОЛЬЗОВАНИЕ (e.department_id) следует добавить
- ГДЕ должен быть добавлен e.department_id в (100,101)
- Ни один из вышеперечисленных
Answer: C. Предложение NATURAL JOIN неявно соответствует всем идентичным именованным столбцам. Чтобы добавить дополнительные условия, можно использовать предложение WHERE.
57.You need to find the results obtained by the above query for all those employees who have salaries greater than 20000. Which of the following clauses should be added / modified to the above query?
- ВКЛ (e.department_id = d.department_id) ГДЕ зарплата> 20000;
- ИСПОЛЬЗОВАНИЕ (e.department_id) ГДЕ зарплата> 20000;
- ИСПОЛЬЗОВАНИЕ (Department_id) ГДЕ зарплата> 20000;
- ГДЕ зарплата> 20000;
Answer: D.
58.If the NATURAL JOIN in the above query is replaced by only JOIN which of the following should be added / modified to the above query to give the results pertaining to Department 100?
- ВКЛ (Department_id = 100);
- ИСПОЛЬЗОВАНИЕ (e.department_id = 100);
- ГДЕ d.department_id = 100;
- ВКЛ (e.department_id = d.department_id и d.department_id = 100);
Answer: D. Экви-соединения могут быть добавлены для дополнительных условий после предложения ON.
59.A report has to be extracted to get the Managers for all the employees in the departments 10 and 20 of a company 'ABC'. Which of the following queries will give the required results? (Consider the table structure as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (employee_id );
SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (b.employee_id = a.employee_id );
SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (a.manager_id = b.employee_id ) WHERE department_id in (10,20);
SELECT a.first_name || ' '||a.last_name "Manager", b.first_name||' '||b.last_name "Employees" FROM employees a join employees b On (a.manager_id = b.employee_id ) WHERE a.department_id in (10,20);
Answer: D. Вариант C неверен, потому что не связанный с псевдонимом Department_id в предложении WHERE вызовет ошибку.
60.Which of the following queries will give results without duplicate values between the two tables EMPLOYEES and DEPARTMENT? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SELECT * FROM employees e NATURAL JOIN department d;
SELECT * FROM employees e JOIN department d;
SELECT * FROM employees e NATURAL JOIN department d USING (e.department_id );
SELECT * FROM employees e FULL OUTER JOIN department d USING (department_id );
Answer: D. FULL OUTER JOIN предоставит все совпадающие, а также несовпадающие строки из обеих таблиц, за исключением повторяющихся значений.
Examine the structures for the tables as given here and answer the questions 61 to 64.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SQL> desc locations
Name Null? Type
----------------------- -------- ----------------
LOCATION_ID NOT NULL NUMBER(4)
STREET_ADDRESS VARCHAR2(40)
POSTAL_CODE VARCHAR2(12)
CITY NOT NULL VARCHAR2(30)
STATE_PROVINCE VARCHAR2(25)
COUNTRY_ID CHAR(2)
SQL> desc locations
Name Null? Type
----------------------- -------- ----------------
LOCATION_ID NOT NULL NUMBER(4)
STREET_ADDRESS VARCHAR2(40)
POSTAL_CODE VARCHAR2(12)
CITY NOT NULL VARCHAR2(30)
STATE_PROVINCE VARCHAR2(25)
COUNTRY_ID CHAR(2)
61.What is true about the following query? (Choose the most appropriate answer)
SELECT *
FROM bonus b, employees e
WHERE b.job_id (+) = e.job_id ;
- На нем будут отображаться все бонусы, полученные всеми сотрудниками.
- В столбце бонусов будет отображаться NULL, если конкретный сотрудник не получил никакого бонуса.
- Оба а и Б
- Ни один из вышеперечисленных
Answer: B. (+) Находится на левой стороне уравнения, что означает ПРАВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ, и наоборот.
62.You have to list all the departments who have no employees yet in a company named 'XYZ'. Which of the following queries will give you the required results?
SELECT department_id , department_name FROM departments d NATURAL JOIN employees e;
SELECT department_id , department_name FROM employees e JOIN departments d ON (e.department_id = d.department_id );
SELECT department_id , department_name FROM employees e LEFT OUTER JOIN departments d USING (department_id );
SELECT department_id , department_name FROM employees e RIGHT OUTER JOIN departments d ON (e.department_id = d.department_id );
Answer: D.
63.You need to extract a report which displays 'No department yet' for all those employees who are yet to be allocated to a department. Which of the following will fulfill the purpose?
SELECT nvl(department_id ,'No department yet') FROM employees e RIGHT OUTER JOIN departments d ON (e.department_id = d.department_id );
SELECT nvl(department_id ,'No department yet') FROM departments d LEFT OUTER JOIN employees e ON (e.department_id = d.department_id );
SELECT nvl(department_id ,'No department yet') FROM employees e LEFT OUTER JOIN departments d ON (e.department_id = d.department_id );
SELECT nvl(department_id ,'No department yet') FROM employees e FULL OUTER JOIN departments d ON (e.department_id = d.department_id );
Answer: C.
64.You need to extract a report which displays all the departments which have not been assigned to a city yet. Which of the following queries will give you the required output?
SELECT department_id , department_name FROM departments d NATURAL JOIN locations l;
SELECT department_id , department_name FROM departments d FULL OUTTER JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d JOIN locations l USING (location_id);
SELECT department_id , department_name FROM departments d LEFT OUTER JOIN locations l ON (d.location_id = l.location_id);
Answer: D.
65.In which two cases an OUTER JOIN should be used?
- Если столбцы соединенных таблиц имеют значения NULL
- Если в соединенных таблицах есть столбцы NOT NULL
- Если в объединенных таблицах есть только несогласованные данные
- Если в объединенных таблицах есть как совпадающие, так и несовпадающие данные
Answer: A, D. Внешнее соединение создается, когда записи необходимо включить в результаты, не имея соответствующих записей в таблицах соединения. Эти записи сопоставляются с записями NULL, поэтому они включаются в вывод.
66.You need to find the salary grade obtained by each employee. Which of the following query will you use? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc grade
Name Null? Type
----------------------- -------- ----------------
GRADE NUMBER
LOSAL NUMBER
HISAL NUMBER
SELECT employee_id , salary, grade FROM employees e JOIN grade g ON g.grade BETWEEN g.losal AND g.hisal
SELECT employee_id , salary, grade FROM employees e FULL OUTER JOIN grade g WHERE g.grade > g.losal AND < g.hisal;
SELECT employee_id , salary, grade FROM employees e JOIN grade g ON (MIN(g.grade) = g.losal AND MAX(g.grade) = g.hisal);
- Ни один из вышеперечисленных
Answer: A.
67.Examine the table structures given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
Оцените этот оператор SQL:
SELECT e.employee_id , (.25* e.salary) + (.5 * e.commission_pct) + (.75 * b.bonus) as calc_val
FROM employees e, bonus b
WHERE e.employee_id = b.employee_id ;
Что будет, если убрать из расчета все скобки?
- Значение, отображаемое в столбце calc_val, будет меньше.
- Значение, отображаемое в столбце calc_val, будет выше.
- В столбце calc_val разницы не будет.
- Будет сообщено об ошибке.
Answer: C.
68.Consider the exhibit and examine the structures of the EMPLOYEES, DEPARTMENTS, and GRADE tables. For which situation would you use a non-equijoin query?
- Найти оценку каждому из сотрудников
- Чтобы указать имя, job_id и имя менеджера для всех сотрудников
- Найти название отдела сотрудников.
- Найти количество сотрудников, работающих в Административном отделе и имеющих доход менее 30000 человек.
Answer: A. Соединение без равенства устанавливает отношения, основанные на чем-либо другом, кроме условия равенства. Значения диапазона, используемые с соединениями, отличными от равенства, должны быть взаимоисключающими.
69.In which three cases would you use the USING clause? (Choose three.)
- Вы хотите создать неэквивалентное соединение.
- Присоединяемые таблицы содержат несколько столбцов NULL.
- Соединяемые таблицы содержат столбцы с одинаковыми именами и разными типами данных.
- Вы хотите использовать НАТУРАЛЬНОЕ соединение, но вы хотите ограничить количество столбцов в условии соединения.
Answer: C, D. Подход JOIN .... USING аналогичен подходу NATURAL JOIN, за исключением того, что общий столбец указан в предложении USING. В предложение USING нельзя включить условие, чтобы указать, как связаны таблицы. Кроме того, квалификаторы столбца нельзя использовать для общего столбца, указанного в предложении USING.
70.If the tables EMPLOYEES and BONUS have two columns with identical names viz: - SALARY and JOB_ID, which of the following queries are equivalent to each other? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
SELECT * FROM employees E JOIN bonus B on (salary, job_id )
SELECT * FROM employees E NATURAL JOIN bonus B on (salary, job_id )
SELECT * FROM employees E JOIN bonus B USING (salary, job_id )
SELECT * FROM employees E JOIN bonus B on (salary, job_id )
Answer: B, C.
71.Examine the table structures as given.
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
Изучите следующие два оператора SQL:
Query 1SELECT first_name,department_id
FROM employees E JOIN departments D
USING (department_id );
Query 2
SELECT first_name,department_id
FROM employees E NATURAL JOIN departments D
USING (department_id );
Какое утверждение верно относительно результата?
- Только запрос 1 выполняется успешно и дает требуемый результат.
- Только запрос 2 выполняется успешно и дает требуемый результат.
- Оба запроса 1 и 2 выполняются успешно и дают разные результаты.
- Оба запроса 1 и 2 выполняются успешно и дают одинаковый требуемый результат.
Answer: D.
72.You need to generate a report showing the department location along with the employee name for all hires made before 20th January, 2013.
Вы задаете следующий запрос:
SELECT department_name , first_name||' '||last_name
FROM employees E JOIN department d
ON ( hire_date < '20-JAN-2013')
JOIN locations L
ON (l.location_id = d.location_id) ;
Какое утверждение верно в отношении вышеуказанного запроса?
- Он успешно выполняется и дает требуемый результат.
- Выполняется успешно, но не дает желаемого результата.
- Это вызывает ошибку, потому что порядок соединения таблиц неправильный.
- Это вызывает ошибку, потому что условия равного соединения и не равного соединения не могут использоваться в одном и том же операторе SELECT.
Answer: B.
73.Examine the structure of the EMPLOYEES table:
Вы хотите узнать, вводились ли какие-либо данные сотрудника более одного раза с использованием разных EMPLOYEE_ID, перечислив все повторяющиеся имена. Какой метод можно использовать для получения желаемого результата?
- self-join
- полное внешнее соединение с самосоединением
- левое внешнее соединение с самосоединением
- правое внешнее соединение с самосоединением
Answer: A. Самосоединение используется, когда таблица должна быть присоединена к самой себе для получения необходимых данных. Псевдонимы таблиц требуются в предложении FROM для выполнения самосоединения.
Examine the structure of the tables DEPARTMENTS and LOCATIONS and answer the questions 74 and 75 that follow.
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
SQL> desc locations
Name Null? Type
----------------------- -------- ----------------
LOCATION_ID NOT NULL NUMBER(4)
STREET_ADDRESS VARCHAR2(40)
POSTAL_CODE VARCHAR2(12)
CITY NOT NULL VARCHAR2(30)
STATE_PROVINCE VARCHAR2(25)
COUNTRY_ID CHAR(2)
74.You need to find out the departments that have not been allocated any location. Which query would give the required result?
SELECT d.department_id , d.department_name FROM departments d JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d RIGHT OUTER JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d FULL JOIN locations l ON (d.location_id = l.location_id);
SELECT d.department_id , d.department_name FROM departments d LEFT OUTER JOIN locations l ON (d.location_id = l.location_id);
Answer: B.
75.You want to list all departments that are not located in any location along with the department name. Evaluate the following query:
SELECT d.department_id , d.department_name ,l.location_id, l.city
FROM departments D __________________ location L
ON (d.location_id = l.location_id);
Какие два параметра JOIN можно использовать в пустом поле в приведенном выше запросе, чтобы получить правильный результат?
- JOIN
- ЕСТЕСТВЕННОЕ СОЕДИНЕНИЕ
- ЛЕВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ
- ПРАВО НАРУЖНОЕ СОЕДИНЕНИЕ
Answer: A, C.
76. You need to generate a report that shows all department IDs, with corresponding employees (if any) and bonus details (if any), for all employees. Which FROM clause gives the required result? (Consider the table structures as given)
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> desc bonus
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER
JOB_ID VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
- ИЗ отделов ВЛЕВО ВНЕШНИЙ СОЕДИНЯЙТЕ сотрудников ИСПОЛЬЗУЯ (Department_id) ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ бонус
- ИСПОЛЬЗОВАНИЕ ПОЛНОГО ВНЕШНЕГО СОЕДИНЕНИЯ (Department_id);
- ОТ бонусных ПРИСОЕДИНЯЙТЕСЬ к сотрудникам ИСПОЛЬЗУЯ (job_id)
- ОТ сотрудников ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ отделы ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ бонус
Answer: A.
77. Examine the following exhibits:
Вы хотите создать отчет, в котором перечислены идентификаторы сотрудников и их соответствующие комиссии и отделы (если есть), существуют ли комиссии или нет. Оцените следующий запрос:
SELECT e.employee_id , bonus, department_name FROM bonus b_____________ employees
USING (job_id ) ____________ departments
USING (department_id )
WHERE commission_pct IS NOT NULL;
Какая комбинация объединений, используемых в пробелах в приведенном выше запросе, дает правильный результат?
- ПРИСОЕДИНИТЬСЯ; ЛЕВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ
- ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ; ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ
- ПРАВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ; ЛЕВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ
- LEFT OUTER JOIN; ПРАВО НАРУЖНОЕ СОЕДИНЕНИЕ
Answer: A.
78.Predict the outcome of the following query.
SELECT e.salary, bonus
FROM employees E JOIN bonus b
USING (salary,job_id );
- Он успешно выполняется.
- Выдает ошибку, потому что бонус в SELECT не имеет псевдонима
- Это вызывает ошибку, потому что в предложении USING не может быть более одного столбца.
- Он выполняется успешно, но результаты неверны.
Answer: D.
View the Exhibit and examine the structure of the EMPLOYEES, DEPARTMENTS, LOCATIONS and BONUS. Answer the questions from 79 and 80 that follow:
79.You need to list all the departments in the city of Zurich. You execute the following query:
SELECT D.DEPARTMENT_ID , D.DEPARTMENT_NAME , L.CITY
FROM departments D JOIN LOCATIONS L
USING (LOC_ID,CITY)
WHERE L.CITY = UPPER('ZURICH');
Спрогнозируйте результат вышеуказанного запроса.
- Он успешно выполняется.
- Выдает ошибку, потому что в операторе SELECT для CITY используется квалификатор.
- Выдает ошибку, потому что имена столбцов в SELECT не совпадают
- Это выдает ошибку, потому что в предложении USING есть CITY, который не является совпадающим столбцом.
Answer: D. В предложении USING следует использовать только совпадающие имена столбцов.
80.Answer the question that follows the query given below:
SELECT e.first_name, d.department_id , e.salary, b.bonus
FROM bonus b join employees e
USING (job_id )
JOIN department d
USING (department_id )
WHERE d.loc = 'Zurich';
Вам необходимо извлечь отчет, в котором указаны имя, номер отдела, зарплата и бонусы сотрудников компании с названием «ABC». Какой из следующих запросов поможет решить эту задачу?
SELECT e.first_name, d.department_id , e.salary, b.bonus FROM bonus b join employees e join departments d on (b.job_id = e.job_id ) on (e.department_id =d.department_id ) WHERE d.loc = 'Zurich';
SELECT e.first_name, d.department_id , e.salary, b.bonus FROM bonus b join employees e on (b.job_id = e.job_id ) JOIN department d on (e.department_id =d.department_id ) WHERE d.loc = 'Zurich';
SELECT e.first_name, d.department_id , e.salary, b.bonus FROM employees e join bonus b USING (job_id ) JOIN department d USING (department_id ) WHERE d.loc = 'Zurich';
- Ни один из вышеперечисленных
Answer: C. Запрос A выдаст синтаксическую ошибку, запрос B выдаст ошибку неверного идентификатора между бонусом и отделом.
Examine the Exhibits given below and answer the questions 81 to 85 that follow.
81. You need to find the managers' name for those employees who earn more than 20000. Which of the following queries will work for getting the required results?
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E JOIN employees M USING (e.manager_id = m.employee_id ) WHERE e.salary >20000;
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E JOIN employees M USING (e.manager_id) WHERE e.salary >20000;
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E NATURAL JOIN employees M USING (e.manager_id = m.employee_id ) WHERE e.salary >20000;
SELECT e.employee_id "Employee", salary, employee_id , FROM employees E JOIN employees M ON (e.manager_id = m.employee_id ) WHERE e.salary >20000;
Answer: D.
82.You issue the following query:
SELECT e.employee_id ,d.department_id
FROM employees e NATURAL JOIN department d NATURAL JOIN bonus b
WHERE department_id =100;
Какое утверждение верно в отношении результата этого запроса?
- Он успешно выполняется.
- Это приводит к ошибке, поскольку НАТУРАЛЬНОЕ соединение может использоваться только с двумя таблицами.
- Это вызывает ошибку, потому что столбец, используемый в NATURAL join, не может иметь квалификатора.
- Это вызывает ошибку, потому что все столбцы, используемые в NATURAL соединении, должны иметь квалификатор.
Answer: C.
83.You want to display all the employee names and their corresponding manager names. Evaluate the following query:
SELECT e.first_name "EMP NAME", m.employee_name "MGR NAME"
FROM employees e ______________ employees m
ON e.manager_id = m.employee_id ;
Какую опцию JOIN можно использовать в пустом поле в приведенном выше запросе, чтобы получить требуемый результат?
- Простой внутренний JOIN
- ПОЛНОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ
- ЛЕВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ
- ПРАВО НАРУЖНОЕ СОЕДИНЕНИЕ
Answer: C. Левое внешнее соединение включает в себя все записи из таблицы, перечисленной в левой части соединения, даже если в операции соединения не найдено совпадений с другой таблицей.
Consider the below exhibit and following query to answer questions 84 and 85. (Assume the table department has manager_id and department_name as its columns)
Select *
FROM employees e JOIN department d
ON (e.employee_id = d.manager_id);
84. You need to display a sentence "(first_name) (last_name) is manager of the (department_name) department". Which of the following SELECT statements will successfully replace '*' in the above query to fulfill this requirement?
SELECT e.first_name||' '||e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
SELECT e.first_name, e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
SELECT e.last_name||' is manager of the '||d.department_name||' department.' "Managers"
- Ни один из вышеперечисленных
Answer: A.
85.What will happen if we omit writing the braces "( )" after the ON clause in the above query?
- В нем будут указаны только имена сотрудников, а имена менеджеров будут исключены из набора результатов.
- Результат будет тот же, что и при использовании фигурных скобок "()"
- Это приведет к ошибке ORA, так как при использовании предложения JOIN..ON обязательно писать фигурные скобки "()".
- Ни один из вышеперечисленных
Answer: B. Скобки не являются обязательными, но их использование обеспечивает четкую читаемость условий внутри них.
86. Which of the following queries creates a Cartesian join?
SELECT title, authorid FROM books, bookauthor;
SELECT title, name FROM books CROSS JOIN publisher;
SELECT title, gift FROM books NATURAL JOIN promotion;
- все вышеперечисленное
Answer: A, B. Декартово соединение между двумя таблицами возвращает все возможные комбинации строк из таблиц. Декартово соединение может быть произведено путем исключения операции соединения в запрос или с помощью CROSS JOIN.
87. Which of the following operators is not allowed in an outer join?
- AND
- =
- OR
- >
Answer: C. Oracle вызывает исключение «ORA-01719: оператор внешнего соединения (+) не разрешен в операнде OR или IN»
88. Which of the following queries contains an equality join?
SELECT title, authorid FROM books, bookauthor WHERE books.isbn = bookauthor.isbn AND retail > 20;
SELECT title, name FROM books CROSS JOIN publisher;
SELECT title, gift FROM books, promotion WHERE retail >= minretail AND retail <= maxretail;
- Ни один из вышеперечисленных
Answer: A. Соединение по равенству создается, когда данные, объединяющие записи из двух разных таблиц, являются точным совпадением (то есть условие равенства создает связь).
89. Which of the following queries contains a non-equality join?
SELECT title, authorid FROM books, bookauthor WHERE books.isbn = bookauthor.isbn AND retail > 20;
SELECT title, name FROM books JOIN publisher USING (pubid);
SELECT title, gift FROM books, promotion WHERE retail >= minretail AND retail <= maxretail;
- Ни один из вышеперечисленных
Answer: D. Nonequijoins соответствует значениям столбцов из разных таблиц на основе выражения неравенства. Значение столбца соединения в каждой строке исходной таблицы сравнивается с соответствующими значениями в целевой таблице. Соответствие обнаружено, если выражение, используемое в соединении, основанное на операторе неравенства, оценивается как истина. Когда такое соединение создается, выполняется неравное объединение. Неэквижное соединение указывается с использованием синтаксиса JOIN..ON, но условие объединения содержит оператор неравенства вместо знака равенства.
90. The following SQL statement contains which type of join?
SELECT title, order#, quantity
FROM books FULL OUTER JOIN orderitems
ON books.isbn = orderitems.isbn;
- equality
- self-join
- non-equality
- внешнее соединение
Answer: D. Полное внешнее соединение включает в себя все записи из обеих таблиц, даже если соответствующая запись в другой таблице не найдена.
91. Which of the following queries is valid?
SELECT b.title, b.retail, o.quantity FROM books b NATURAL JOIN orders od NATURAL JOIN orderitems o WHERE od.order# = 1005;
SELECT b.title, b.retail, o.quantity FROM books b, orders od, orderitems o WHERE orders.order# = orderitems.order# AND orderitems.isbn=books.isbn AND od.order#=1005;
SELECT b.title, b.retail, o.quantity FROM books b, orderitems o WHERE o.isbn = b.isbn AND o.order#=1005;
- Ни один из вышеперечисленных
Answer: C. Если таблицы в объединениях имеют псевдоним, на выбранные столбцы следует ссылаться с псевдонимом, а не с фактическими именами таблиц.
92. Given the following query.
SELECT zip, order#
FROM customers NATURAL JOIN orders;
Какой из следующих запросов эквивалентен?
SELECT zip, order# FROM customers JOIN orders WHERE customers.customer# = orders.customer#;
SELECT zip, order# FROM customers, orders WHERE customers.customer# = orders.customer#;
SELECT zip, order# FROM customers, orders WHERE customers.customer# = orders.customer# (+);
- ни один из вышеперечисленных
Answer: B. Естественное соединение указывает Oracle идентифицировать столбцы с идентичными именами между исходной и целевой таблицами.
93. Examine the table structures as given. Which line in the following SQL statement raises an error?
SQL> DESC employees
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL> DESC departments
Name Null? Type
----------------------- -------- ----------------
DEPARTMENT_ID NOT NULL NUMBER(4)
DEPARTMENT_NAME NOT NULL VARCHAR2(30)
MANAGER_ID NUMBER(6)
LOCATION_ID NUMBER(4)
1. SELECT e.first_name, d.department_name
2. FROM employees e, department d
3. WHERE e.department_id=d.department_id
- линия 1
- строка 2
- строка 3
- Нет ошибок
Answer: A. Если запрос использует псевдонимы в условии соединения, их столбец должен использовать псевдоним для ссылки.
94. Given the following query:
SELECT lastname, firstname, order#
FROM customers LEFT OUTER JOIN orders
USING (customer#)
ORDER BY customer#;
Какой из следующих запросов возвращает те же результаты?
SELECT lastname, firstname, order# FROM customers c OUTER JOIN orders o ON c.customer# = o.customer# ORDER BY c.customer#;
SELECT lastname, firstname, order# FROM orders o RIGHT OUTER JOIN customers c ON c.customer# = o.customer# ORDER BY c.customer#;
SELECT lastname, firstname, order# FROM customers c, orders o WHERE c.customer# = o.customer# (+) ORDER BY c.customer#;
- Ни один из вышеперечисленных
Answer: B, C.
95. Which of the below statements are true?
- Групповые функции нельзя использовать с данными из нескольких источников данных.
- Если несколько таблиц, объединенных в запрос, содержат одинаковые столбцы, Oracle выбирает только одну из них.
- Естественное соединение используется для объединения строк из двух таблиц на основе одинаковых столбцов.
- А и Б
Answer: C. Групповые функции могут использоваться в запросе с использованием соединений Oracle. На неоднозначные столбцы необходимо ссылаться с помощью квалификатора.
96. Which line in the following SQL statement raises an error?
1. SELECT name, title
2. FROM books JOIN publisher
3. WHERE books.pubid = publisher.pubid
4. AND
5. cost < 45.95
- линия 1
- строка 2
- строка 3
- строка 4
Answer: C. Поскольку таблицы объединяются с помощью ключевого слова JOIN, условие равенства должно быть записано с предложением USING, а не с предложением WHERE.
97. Given the following query:
SELECT title, gift
FROM books CROSS JOIN promotion;
Какой из следующих запросов эквивалентен?
SELECT title, gift FROM books NATURAL JOIN promotion;
SELECT title FROM books INTERSECT SELECT gift FROM promotion;
SELECT title FROM books UNION ALL SELECT gift FROM promotion;
SELECT title, gift FROM books, promotion;
Answer: D. Декартовы соединения аналогичны перекрестным соединениям.
98. If the CUSTOMERS table contains seven records and the ORDERS table has eight records, how many records does the following query produce?
SELECT *
FROM customers CROSS JOIN orders;
- 0
- 56
- 7
- 15
Answer: B. Перекрестное соединение - это перекрестное произведение строк, содержащихся в двух таблицах.
99. Which of the following SQL statements is not valid?
SELECT b.isbn, p.name FROM books b NATURAL JOIN publisher p;
SELECT isbn, name FROM books b, publisher p WHERE b.pubid = p.pubid;
SELECT isbn, name FROM books b JOIN publisher p ON b.pubid = p.pubid;
SELECT isbn, name FROM books JOIN publisher USING (pubid);
Answer: A. Неоднозначные столбцы необходимо указывать с помощью квалификаторов таблицы.
100. Which of the following lists all books published by the publisher named 'Printing Is Us'?
SELECT title FROM books NATURAL JOIN publisher WHERE name = 'PRINTING IS US';
SELECT title FROM books, publisher WHERE pubname = 1;
SELECT * FROM books b, publisher p JOIN tables ON b.pubid = p.pubid WHERE name = 'PRINTING IS US';
- ни один из вышеперечисленных
Answer: A. Предполагая, что столбец NAME не содержится в таблице BOOKS, запрос A действителен.
101. Which of the following SQL statements is not valid?
SELECT isbn FROM books MINUS SELECT isbn FROM orderitems;
SELECT isbn, name FROM books, publisher WHERE books.pubid (+) = publisher.pubid (+);
SELECT title, name FROM books NATURAL JOIN publisher
- Все приведенные выше операторы SQL действительны.
Answer: B. Запрос B вызывает исключение «ORA-01468: предикат может ссылаться только на одну внешнюю соединенную таблицу».
102. Which of the following statements about an outer join between two tables is true?
- Если связь между таблицами устанавливается с помощью предложения WHERE, обе таблицы могут включать в себя оператор внешнего соединения.
- Чтобы включить в результаты несовпадающие записи, запись объединяется с NULL-записью в недостающей таблице.
- Ключевые слова RIGHT, LEFT и FULL эквивалентны.
- все вышеперечисленное
Answer: B.
103. Which line in the following SQL statement raises an error?
1. SELECT name, title
2. FROM books b, publisher p
3. WHERE books.pubid = publisher.pubid
4. AND
5. (retail > 25 OR retail-cost > 18.95);
- линия 1
- строка 3
- строка 4
- строка 5
Answer: B. Поскольку таблицы, используемые в запросе, имеют квалификатор, ссылки на столбцы должны выполняться с его помощью.
104. What is the maximum number of characters allowed in a table alias?
- 10
- 155
- 255
- 30
Answer: D. Псевдоним таблицы может содержать не более 30 символов.
105. Which of the following SQL statements is valid?
SELECT books.title, orderitems.quantity FROM books b, orderitems o WHERE b.isbn= o.ibsn;
SELECT title, quantity FROM books b JOIN orderitems o;
SELECT books.title, orderitems.quantity FROM books JOIN orderitems ON books.isbn = orderitems.isbn;
- ни один из вышеперечисленных
Answer: C.