Вопросы по созданию других объектов схемы
1. Which database object among the following provides a layer of abstraction between the users and the data?
- Table
- Rows
- Views
- Synonyms
Answer: C, D. Представления и синонимы сами по себе не хранят данные. Представление - это временная или виртуальная таблица, используемая для извлечения данных, хранящихся в базовых таблицах базы данных.
2. Which of the following data base objects can generate serial numbers?
- Synonyms
- Views
- Tables
- Sequences
Answer: D. Последовательность может быть создана для генерации серии целых чисел. Значения, сгенерированные последовательностью, можно сохранить в любой таблице. Последовательность создается командой CREATE SEQUENCE.
3. What is true about views?
- Они равны таблицам
- Они хранят данные из одной или нескольких таблиц
- Мы можем выполнять SELECT и другие DML в простых представлениях
- Представления имеют то же пространство имен, что и таблицы, и, следовательно, таблица и представление не могут иметь одинаковое имя.
Answer: C, D. Операции DML не разрешены для представлений, которые включают групповые функции, предложение GROUP BY, псевдостолбец ROWNUM или ключевое слово DISTINCT.
4. Why are views useful? (Choose the most appropriate answer)
- Потому что у них имена короче, чем у таблиц
- Чтобы запретить пользователям доступ к столбцам таблиц
- Чтобы упростить пользовательский SQL
- Все вышеперечисленное
Answer: B, C. Представление - это временная или виртуальная таблица, используемая для извлечения данных, хранящихся в базовых таблицах базы данных. Запрос представления должен выполняться каждый раз при использовании представления. Представление можно использовать для упрощения запросов или ограничения доступа к конфиденциальным данным.
5. In which of the below scenarios, DML operations on a view are not possible?
- Представление содержит предложение GROUP BY
- Базовые таблицы содержат столбцы NOT NULL, но не выбраны в запросе представления
- Запрос просмотра использует псевдостолбец ROWNUM
- Все вышеперечисленное
Answer: D. Операции DML не разрешены для представлений, которые включают групповые функции, предложение GROUP BY, псевдостолбец ROWNUM или ключевое слово DISTINCT.
6. Where can views get their data from?
- Таблицы из одной схемы
- Таблицы из другой схемы
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C.
Consider the given table structure and the following statement and answer the questions 7 to 9 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)
CREATE VIEW emp_details AS
SELECT hire_date, job, salary, department_id FROM employees;
7. You issue the below query. How many columns will the user see as a result of the below query?
SELECT * FROM emp_details WHERE department_id= 100;
- 0
- 1
- 2
- 4
Answer: D. Поскольку определение представления основано на четырех столбцах из таблицы EMPLOYEES, запрос к представлению со всеми столбцами покажет только эти четыре столбца.
8. You need to get the department name in addition to the above 4 columns. Which of the following query will give you the required results?
SELECT E.*, dept_name FROM departments D join emp_details E ON (E.department_id= D.dept_id);
SELECT hire_date, job, salary, dept_name FROM emp_details
- Это невозможно, представление не может быть объединено с другими таблицами
- Ни один из вышеперечисленных
Answer: A. Представление можно объединить с другими таблицами или представлениями в запросе SELECT.
9. You need to find the maximum salary along with the department name in addition to the 4 columns selected in the view. Which of the following query will give you the required results?
Select dept_name, e.salary FROM departments D join emp_details E On (E.department_id= D.dept_id);
Select dept_name, max(salary) FROM departments D join emp_details E On (E.department_id= D.dept_id) Group by dept_name;
- Просмотр не может отображаться в запросах с использованием групповых функций
Select dept_name, max(salary) FROM departments D join emp_details E On (E.department_id= D.dept_id);
Answer: B.
10. What among the following is true about synonyms?
- Синонимы PUBLIC и PRIVATE могут иметь одно и то же имя для одной и той же таблицы.
- DROP SYNONYM удалит синоним
- DROP PUBLIC SYNONYM может быть выполнен только SYSDBA
- Ни один из вышеперечисленных
Answer: A, C. Синоним может быть частным синонимом, который пользователи используют для ссылки на принадлежащие им объекты, или общедоступным синонимом, который пользователи используют для доступа к объектам базы данных другого пользователя. Только SYSDBA или пользователь с привилегиями администратора базы данных могут создать общедоступный синоним.
11. What is true about creating a view? (Choose the most appropriate answer)
- Представление можно создать только из таблицы
- Представление можно создать только из одной таблицы
- Представление может быть создано из одной или нескольких таблиц или представлений.
- Ни один из вышеперечисленных
Answer: C. Представление, содержащее выражения или функции или объединяющее несколько таблиц, считается сложным представлением. Сложное представление можно использовать для обновления только одной таблицы.
12. Which of the following privileges are required to create views in one's own schema?
- Системная привилегия CREATE TABLE
- Системная привилегия CREATE VIEW
- Системная привилегия ALTER VIEW
- СОЗДАЙТЕ ЛЮБУЮ системную привилегию просмотра
Answer: B. Право CREATE VIEW требуется пользователю для создания представления в его собственной схеме.
13. Which of the following privileges are required to create views in someone else's schema?
- СОЗДАТЬ ЛЮБОЙ ПРОСМОТР
- СОЗДАТЬ ПРОСМОТР
- Оба а и Б
- Ни один из вышеперечисленных
Answer: A. Право CREATE ANY VIEW требуется пользователю для создания представления в схеме другого пользователя.
14.Which of the following are supported for an object view or relational view?
- LOBs
- Типы объектов
- Типы данных REF
- Все вышеперечисленное
Answer: D.
15. What among the following are different types of Views?
- Простые представления
- Комплексные представления
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C. Простые и сложные представления - это два типа представлений. Простые представления основаны на подзапросе, который ссылается только на одну таблицу и не включает групповые функции, выражения или предложения GROUP BY. Сложные представления основаны на подзапросе, который извлекает или извлекает данные из одной или нескольких таблиц и может содержать функции или сгруппированные данные.
16. What is true about a simple view?
- Операторы DML в большинстве случаев могут выполняться против простых представлений
- Есть только одна исходная базовая таблица
- Групповые функции не используются
- Все вышеперечисленное
Answer: D. Простые представления основаны на подзапросе, который ссылается только на одну таблицу и не включает групповые функции, выражения или предложения GROUP BY.
17.What is true about a complex view?
- Операторы DML не могут применяться к сложным представлениям
- Содержат несколько базовых таблиц
- Агрегации не могут быть выполнены
- Все вышеперечисленное
Answer: D. Сложные представления основаны на подзапросе, который извлекает или извлекает данные из одной или нескольких таблиц и может содержать функции или сгруппированные данные.
18.Which keyword combination should be used to implicitly drop a view (if it exists) and create a new view with the same name?
- СОЗДАТЬ ПРОСМОТР
- ЗАМЕНИТЬ ВИД
- СОЗДАТЬ ИЛИ ЗАМЕНИТЬ ВИД
- Ни один из вышеперечисленных
Answer: C. Опция OR REPLACE уведомляет Oracle 11g о том, что представление с таким именем может уже существовать; если это так, предыдущая версия представления должна быть заменена версией, определенной в новой команде.
19.How is a view stored in the data dictionary?
- В качестве предложения WHERE
- Как оператор CREATE
- Как оператор UPDATE
- Как оператор SELECT
Answer: D.
20.Which of the following can contain single-row functions?
- Встроенные представления
- Простые представления
- Комплексные представления
- Составные представления
Answer: A, B. Однострочные функции можно использовать как в встроенных, так и в простых представлениях.
21.Which of the following can contain a group of data?
- Композитный вид
- Простой вид
- Комплексный вид
- Ни один из вышеперечисленных
Answer: C. Комплексное представление может использовать групповую функцию в запросе.
22.What among the following is true about a View?
- Подзапросы могут быть встроены в оператор CREATE VIEW
- Подзапрос, используемый в операторе CREATE VIEW, должен иметь простой синтаксис SELECT.
- Вы не можете использовать предложение WHERE в подзапросе, когда оно используется в инструкции CREATE VIEW
- Ни один из вышеперечисленных
Answer: A. Определение представления может использовать подзапросы.
23.Which of the following can create a view even if the base table(s) does not exist?
- NOFORCE
- FORCE
- ИЛИ ЗАМЕНИТЬ
- СОЗДАТЬ ПРОСМОТР
Answer: B. Если вы включите ключевое слово FORCE в предложение CREATE, Oracle 11g создаст представление, несмотря на отсутствие каких-либо таблиц, на которые есть ссылки. NOFORCE - это режим по умолчанию для команды CREATE VIEW, что означает, что все таблицы и столбцы должны быть действительными, или представление не создается.
24.Which of the following commands ensures that no DML operations can be performed on a view?
- NOFORCE
- FORCE
- ТОЛЬКО ЧИТАТЬ
- ИЛИ ЗАМЕНИТЬ
Answer: C. Параметр WITH READ ONLY предотвращает выполнение любых операций DML с представлением. Этот параметр часто используется, когда важно, чтобы пользователи могли только запрашивать данные, а не вносить в них какие-либо изменения.
25.What is true about the NOFORCE option in CREATE VIEW statement?
- Он создает представление, даже если базовая таблица (-ы) не существует.
- Он создает представление только в том случае, если существует базовая таблица (и).
- Это значение по умолчанию при создании представления.
- Ни один из вышеперечисленных
Answer: B, C. NOFORCE - это режим по умолчанию для команды CREATE VIEW, что означает, что все таблицы и столбцы должны быть действительными, или представление не создается.
26.What is true about the OR REPLACE keyword?
- Привилегии объекта теряются, когда представление создается с использованием этого ключевого слова
- Нет необходимости повторно предоставлять объектные привилегии, ранее предоставленные ему.
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: B. Опция OR REPLACE уведомляет Oracle 11g о том, что представление с таким именем может уже существовать; если это так, предыдущая версия представления должна быть заменена версией, определенной в новой команде.
27.What is true with respect to accessing the below view? (Assume the table structure 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)
CREATE VIEW salVU100
AS SELECT employee_id ID_NUMBER, last_name NAME, salary*12 ANNUAL_SAL
FROM employees E
WHERE department_id= 100;
- Доступ к представлению должен осуществляться по исходным именам столбцов, определенным в базовой таблице.
- Доступ к представлению должен осуществляться по псевдонимам, указанным в запросе представления.
- Просмотр - это простой вид
- Ни один из вышеперечисленных
Answer: B, C. Представление должно ссылаться на псевдоним столбца, если определение представления содержит псевдоним для столбцов.
28.What is true with respect to accessing the below view? (Assume the table structure 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)
CREATE VIEW salVU100 (ID_NUMBER, NAME, ANNUAL_SAL)
AS SELECT employee_id , last_name, salary*12
FROM employees E
WHERE department_id= 100;
- Необязательно, чтобы количество псевдонимов совпадало с номером. выражений в подзапросе
- Это обязательно, что нет. перечисленных псевдонимов должны соответствовать номеру. выражений, выбранных в подзапросе
- При создании представления обязательно указывать псевдонимы.
- Ни один из вышеперечисленных
Answer: B. Если псевдоним указан в заголовке представления, в запросе SELECT должно быть выбрано такое же количество столбцов.
29. Consider the following statement and the given table structure:
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)
CREATE OR REPLACE VIEW empVU100
(ID_NUMBER, NAME, ANNUAL_SAL, DEPT_ID)
AS
SELECT employee_id , first_name ||' '|| last_name, salary, department_id
FROM employees
WHERE department_id= 100;
Что верно для псевдонимов столбцов, как в приведенном выше запросе?
- Псевдонимы столбцов перечислены в случайном порядке как столбцы в подзапросе.
- Псевдонимы столбцов перечислены в том же порядке, что и столбцы в подзапросе.
- При использовании ключевого слова CREATE OR REPLACE псевдонимы столбцов являются обязательными.
- Мы не можем использовать конкатенацию, когда используем CREATE OR REPLACE
Answer: B.
Consider the following statement and answer the questions 30 to 34 that follow:
CREATE OR REPLACE VIEW dept_sum_vu (name, minsal, maxsal, avgsal)
AS
SELECT d.dept_name, MIN(e.salary), MAX(e.salary), AVG (e.salary)
FROM employees e JOIN departments d
ON (e.department_id= d.dept_id)
GROUP BY d.dept_name;
30.What can be said about the statement given above?
- Для вида были даны альтернативные названия
- Предоставление альтернативных имен обязательно, если какой-либо столбец является производным от функции или выражения.
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C. Указание псевдонима - хороший способ улучшить читаемость кода и запросов просмотра.
31.What will happen if the above statement is modified as below?
CREATE OR REPLACE VIEW dept_sum_vu(name, maxsal, minsal, avgsal)
AS
SELECT d.dept_name, MIN(e.salary), MAX(e.salary), AVG (e.salary)
FROM employees e JOIN departments d
ON (e.department_id= d.dept_id)
GROUP BY d.dept_name;
- Он не будет отличаться от исходного заявления
- Он будет успешно выполнен с теми же результатами, но с изменением псевдонимов.
- Выдает ошибку ORA
- Ни один из вышеперечисленных
Answer: B. Последовательность псевдонимов столбцов не имеет большого значения, поскольку они не несут никаких поведенческих атрибутов.
32.Determine the output of the below DELETE statement.
DELETE FROM dept_sum_vu;
- Это удалит представление
- Он удалит все строки из представления, но структура представления останется прежней.
- Выдает ошибку ORA
- Ни один из вышеперечисленных
Answer: C. Представление DEPT_SUM_VU - сложное представление. Операции DML нельзя выполнять со сложным видом.
33.Suppose you modify the query given above to the following:
CREATE OR REPLACE VIEW dept_sum_vu(name, sal)
AS
SELECT d.dept_name, e.salary
FROM employees e JOIN departments d
ON (e.department_id= d.dept_id)
Where rownum < 10;
На что повлияет модификация?
- Представление можно обновить, чтобы обновить значения в таблицах EMPLOYEES и DEPARTMENTS.
- Данные в таблицах EMPLOYEES и DEPARTMENTS нельзя удалить через представление
- Данные в таблицы EMPLOYEES и DEPARTMENTS можно вставлять через представление
- Столбец можно добавить в таблицу EMPLOYEES через представление
Answer: B. Операции DML не могут выполняться на сложных представлениях. DEPT_SUM_VU - сложное представление, поскольку оно объединяет несколько таблиц. DDL-операции с представлениями невозможны.
34.Suppose you select DISTINCT departments and employee salaries in the view query used in above question. What will be the outcome if you try to remove rows from the view dept_sum_vu?
- Строки будут удалены без ошибок
- Будут удалены только первые 10 строк.
- Строки нельзя удалить.
- Ни один из вышеперечисленных
Answer: C. Представление DEPT_SUM_VU по-прежнему является сложным представлением, поскольку оно использует ключевое слово DISTINCT. Следовательно, операции DML с ним невозможны.
35.When can the rows from a view be removed?
- Удаление строк через представление невозможно
- Должен быть простой вид
- Должен быть комплексный вид
- Ни один из вышеперечисленных
Answer: B. Операции DML возможны только на простых представлениях.
36.When can the data in a view not be modified?
- Когда есть групповые выражения
- Когда есть предложение GROUP BY
- Когда ROWNUM используется в запросе просмотра
- Все вышеперечисленное
Answer: D. ОБНОВЛЕНИЕ невозможно для представления, содержащего групповые функции, псевдостолбцы или ключевое слово DISTINCT.
37. The JOB_HISTORY table is owned by a user "Andy". Andy grants the SELECT privilege on the JOB_HISTORY table to another user "HR". Which statement would create a synonym EMP_JOBS so that "HR" can execute the following query successfully?(Assume the structure of tables as given)
SQL> desc job_history
Name Null? Type
----------------------- -------- ----------------
EMPLOYEE_ID NOT NULL NUMBER(6)
START_DATE NOT NULL DATE
END_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
DEPARTMENT_ID NUMBER(4)
SELECT * from EMP_JOBS;
- Энди вопросы -
CREATE SYNONYM EMP_JOBS for JOB_HISTORY
- Кадровые вопросы -
CREATE SYNONYM EMP_JOBS for andy.JOB_HISTORY
- Кадровые вопросы -
CREATE PUBLIC SYNONYM EMP_JOBS FOR andy.JOB_HISTORY
- Ни один из вышеперечисленных
Answer: B. Только SYSDBA или пользователь с привилегиями администратора базы данных могут создавать общедоступные синонимы.
38.Which keyword can assure that the DML operations performed on the view stay in the domain of the view?
- ИЛИ ЗАМЕНИТЬ
- CREATE
- С ОПЦИЕЙ ПРОВЕРКИ
- Ни один из вышеперечисленных
Answer: C. Ограничение WITH CHECK OPTION гарантирует, что любые операции DML, выполняемые в представлении (например, добавление строк или изменение данных), не препятствуют доступу представления к строке, поскольку оно больше не соответствует условию в предложении WHERE.
Consider the following table structure and the given statement and answer the questions 39 and 40 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)
CREATE OR REPLACE VIEW empvu100
AS
SELECT * FROM employees
WHERE department_id= 100
WITH CHECK OPTION CONSTRAINT empvu100_ck;
39.What will the above statement do?
- Это позволит пользователям выполнять INSERT или UPDATE во всех отделах.
- Это позволит пользователю выполнить INSERT или UPDATE для любой строки, в которой есть отдел 100.
- Пользователь может ОБНОВЛЯТЬ любую строку в таблице сотрудников.
- Пользователь может ВСТАВИТЬ строки без каких-либо ограничений в таблице сотрудников.
Answer: B. Ограничение WITH CHECK OPTION гарантирует, что любые операции DML, выполняемые в представлении (например, добавление строк или изменение данных), не препятствуют доступу представления к строке, поскольку оно больше не соответствует условию в предложении WHERE. Ошибка ORA будет выдана, если INSERT или UPDATE будут выполнены в любой строке с идентификатором отдела, отличным от 100.
40.Suppose you fire an UPDATE statement as shown below:
UPDATE empvu100
Set department_id = 200
Where employee_id = 121;
Каков будет итог этого заявления?
- Строки не обновляются
- Выдается ошибка ORA
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C. Если представление с CHECK OPTION обновляется и новое значение записи нарушает область просмотра, возникает исключение ORA «ORA-01402: view WITH CHECK OPTION нарушение where-clause».
41.What is true about the WITH CHECK CONSTRAINT?
- Операции INSERT или UPDATE, выполняемые через представление, не могут создавать строки, которые представление не может выбрать
- Только операции INSERT, выполняемые через представление, не могут создавать строки, которые представление не может выбрать
- Только ОБНОВЛЕНИЯ, выполняемые через представление, не могут создавать строки, которые представление не может выбрать
- Ни один из вышеперечисленных
Answer: A.
42.How can you prevent DML operations on a View?
- Путем определения ограничения WITH CHECK OPTION
- Определив параметр ТОЛЬКО ДЛЯ ЧТЕНИЯ
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: B. Параметр WITH READ ONLY предотвращает выполнение любых операций DML с представлением. Этот параметр часто используется, когда важно, чтобы пользователи могли только запрашивать данные, а не вносить в них какие-либо изменения.
Consider the table structure and the given statement and answer the questions 43, 44 and 45 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)
CREATE OR REPLACE empvu100(employee_id , first_name, job)
AS
SELECT employee_id , last_name, job
FROM employees
WHERE department_id = 100
WITH READ ONLY;
43.What is true about the above statement?
- Представление не будет создано
- Операция INSERT в этом представлении вызовет ошибку ORA
- При ОБНОВЛЕНИИ строк для всех сотрудников в отделе 100 будет выдана ошибка ORA.
- Ни один из вышеперечисленных
Answer: B, C. Операции DML не разрешены для просмотра, созданного с опцией ТОЛЬКО ДЛЯ ЧТЕНИЯ.
44.How many rows can be deleted from the view as shown above?
- Все строки вида
- Все ряды только отдела 100
- Нет строк
- Ни один из вышеперечисленных
Answer: C. Операции DML не разрешены для просмотра, созданного с опцией ТОЛЬКО ДЛЯ ЧТЕНИЯ.
45.Which of the following statements will drop the view created as above?
DROP READ ONLY VIEW empvu100;
DROP NOFORCE empvu100;
DROP VIEW empvu100;
- Ни один из вышеперечисленных
Answer: C. Представление только для чтения можно удалить с помощью команды DROP VIEW.
46.What is true about dropping a View?
- Столбцы в представлении из базовых таблиц также удаляются.
- Определение представления удаляется из базы данных
- Удаление представления не влияет на базовую таблицу.
- Ни один из вышеперечисленных
Answer: B, C.
47.Which of the following privileges should a user have to drop a view?
- СОЗДАТЬ ЛЮБОЙ ПРОСМОТР
- СОЗДАТЬ ПРОСМОТР
- ОТКАЗАТЬ ЛЮБОЙ ПРОСМОТР
- ПОКАЗАТЬ ВИД
Answer: C.
48.What is true about sequences?
- Он генерирует целые числа
- Это разделяемый объект
- Может использоваться для создания значения PRIMARY KEY
- Все вышеперечисленное
Answer: D. Последовательность повышает эффективность доступа к значениям последовательности при кэшировании в памяти
49.What is true about a sequence?
- Он создается при установке Oracle Database.
- Он создается пользователем с системной привилегией CREATE SEQUENCE.
- Его не могут использовать более двух пользователей
- Он автоматически отключается при отключении базы данных.
Answer: B, C. Системная привилегия CREATE SEQUENCE требуется пользователю для создания последовательности в своей собственной схеме, которая не может использоваться другими пользователями.
50.What among the following options is true about Sequences?
- Целые числа, сгенерированные с помощью последовательности для одной таблицы, не могут использоваться другими таблицами.
- Последовательность можно только увеличивать
- Последовательность становится недействительной, если другая последовательность генерирует те же целые числа.
- Последовательность может использоваться во многих таблицах, и их можно увеличивать или уменьшать
Answer: D.
Consider the following statement and answer the questions 51 to 59 that follow:
CREATE SEQUENCE dept_deptid_seq
INCREMENT BY 100
START WITH 101
MAXVALUE 9999
NOCACHE
NOCYCLE;
51.What will be the first value generated by this sequence?
- 1
- 100
- 101
- 9999
Answer: C. Предложение START WITH устанавливает начальное значение для последовательности. Oracle 11g начинает каждую последовательность с 1, если другое значение не указано в предложении START WITH.
52.What can be the last value generated by this sequence?
- 0
- 100
- 101
- 9999
Answer: D. Предложения MINVALUE и MAXVALUE устанавливают минимальное или максимальное значение для последовательности.
53.What will be the 2nd value generated by this sequence?
- 102
- 100
- 99
- 9999
Answer: A. Предложение INCREMENT BY определяет интервал между двумя последовательными значениями. Если последовательность увеличивается на положительное значение, значения, генерируемые последовательностью, располагаются в порядке возрастания. Однако, если указано отрицательное значение, значения, генерируемые последовательностью, находятся в порядке убывания. Если предложение INCREMENT BY не включено при создании последовательности, используется параметр по умолчанию, который увеличивает последовательность на единицу для каждого сгенерированного целого числа.
54.What will be the next value after the maximum integer 9999 is reached by this sequence?
- 101
- Неважно
- Выдает ошибку ORA
- Ни один из вышеперечисленных
Answer: B. Опции CYCLE и NOCYCLE определяют, должен ли Oracle 11g начать повторную выдачу значений из последовательности после достижения минимального или максимального значения.
55.How many values will Oracle pre allocate in memory based on the sequence given above?
- 20
- 0
- 100
- 9999
Answer: A.
56.You execute the below query:
SELECT dept_depid_seq.NEXTVAL from dual;
- 200
- 101
- 9999
- 201
Answer: D. Псевдостолбец NEXTVAL будет генерировать следующее уникальное целое число последовательности.
57.You execute the below query:
SELECT dept_depid_seq.CURRVAL from dual;
- 200
- 101
- 9999
- 201
Answer: A. Псевдостолбец CURRVAL будет генерировать текущее уникальное целое число, уже сгенерированное последовательностью.
58.Suppose you need to change the start value of this sequence to 1000. Which of the following statements will help?
ALTER dept_deptid_seq INCREMENT BY 100 START WITH 1000 MAXVALUE 9999 NOCACHE NOCYCLE;
- Последовательность должна быть отброшена и создана заново, чтобы начать последовательность с 1000.
ALTER SEQUENCE dept_deptid_seq START WITH 101
ALTER SEQUENCE dept_deptid_seq INCREMENT BY 100 START WITH 101 CYCLE;
Answer: B. Начальный номер последовательности изменить нельзя. Oracle вызывает исключение «ORA-02283: невозможно изменить начальный порядковый номер».
59.Suppose that the above sequence is altered as below:
ALTER SEQUENCE dept_deptid_seq
INCREMENT BY 100
START WITH 101
MAXVALUE 99
NOCACHE
NOCYCLE;
Что будет в результате этого изменения?
- Ошибка ORA
- Максимальное значение для измененной последовательности теперь будет 99.
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: A. MAXVALUE не может быть меньше значения START WITH при изменении последовательности.
60.When can we use the CYCLE option in Sequences?
- Если мы хотим быстрее очистить старые строки
- Если мы не хотим использовать последовательность для генерации значений PRIMARY KEY
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C. Опции CYCLE и NOCYCLE определяют, должен ли Oracle 11g начать повторную выдачу значений из последовательности после достижения минимального или максимального значения. Если указана опция CYCLE и Oracle 11g достигает максимального значения для возрастающей последовательности или минимального значения для убывающей последовательности, опция CYCLE снова инициирует цикл чисел.
61.What is true about NEXTVAL pseudo column?
- Он повторно генерирует CURRVAL последовательности
- Возвращает следующее доступное значение последовательности
- Может возвращать повторяющиеся значения
- Он генерирует одинаковые значения для разных пользователей
Answer: B. Псевдостолбец NEXTVAL (NEXT VALUE) используется для фактического создания значения последовательности. Другими словами, он вызывает объект последовательности и запрашивает значение следующего числа в последовательности. После создания значения оно сохраняется в псевдостолбце CURRVAL (CURRENT VALUE), чтобы вы могли ссылаться на него снова.
62.What is true about CURRVAL pseudo column?
- CURRVAL может использоваться перед NEXTVAL по отношению к последовательности
- CURRVAL дает текущее значение последовательности
- CURRVAL может давать повторяющиеся значения
- Ни один из вышеперечисленных
Answer: B.
63.When can NEXTVAL and CURRVAL be used?
- Предложение SET оператора INSERT
- Предложение VALUES оператора UPDATE
- Список SELECT оператора SELECT, который не является частью подзапроса
- Список SELECT оператора INSERT
Answer: C, D. Последовательность может использоваться в запросе SELECT, курсоре PL / SQL или в прямых операциях IAS (INSERT-AS-SELECT).
64.When can NEXTVAL and CURRVAL not be used?
- Список SELECT представления
- Оператор SELECT с ключевым словом DISTINCT
- Подзапрос в инструкции SELECT, DELETE или UPDATE
- Все вышеперечисленное
Answer: D.
Consider the given statement and answer the questions 65 and 66 that follow:
CREATE TABLE employees
(employee_id NUMBER(4) DEFAULT emp_empid_seq.CURRVAL,
department_id NUMBER(4));
65.What will be the outcome of this statement? (Assume that emp_empid_seq is sequence used to generate employee ID values)
- Таблица будет создана
- В столбце Department_id будут значения из последовательности, созданной для идентификатора сотрудника.
- Столбец Department_id будет иметь значение DEFAULT.
- Ошибка ORA
Answer: D. Псевдостолбцы нельзя указать в предложении DEFAULT определения столбца.
66.What will be the outcome of this statement if the CURRVAL is replaced with NEXTVAL? (Assume that emp_empid_seq is generated to generate employee ID values)
- Таблица будет создана
- В столбце Department_id будут значения из последовательности, созданной для идентификатора сотрудника.
- Столбец Department_id будет иметь значение DEFAULT.
- Ошибка ORA
Answer: D. Псевдостолбцы нельзя указать в предложении DEFAULT определения столбца.
Examine the given exhibit giving the structures of the tables Departments and Location. Answer the questions 67 and 68 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)
67.You need to insert a new department named "HR" in the location ID 1000. Which of the following statements will give you the required results?
INSERT INTO departments (dept_id, dept_name, location_id) VALUES (dept_deptid_seq.NEXTVAL, 'HR', 1000);
INSERT INTO departments (dept_id, dept_name, location_id) VALUES (dept_deptid_seq.NEXTVAL, "HR", 1000);
INSERT INTO departments (dept_id, dept_name, location_id) VALUES (dept_deptid_seq.CURRVAL, 'HR', 1000);
- Ни один из вышеперечисленных
Answer: A.Параметр C вызовет «Нарушение уникального ограничения», поскольку он попытается вставить текущее значение идентификатора отдела, которое уже существует в таблице DEPARTMENTS.
68.Suppose you execute the below query before inserting the values as shown in the option A in question 67. What will be the outcome of the query?
SELECT dept_deptid_seq.CURRVAL FROM DUAL;
- Ошибка ORA
- Это даст текущее значение последовательности
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: B. Когда пользователь входит в Oracle 11g, значение в псевдостолбце CURRVAL изначально не сохраняется; текущее значение - NULL. После вызова NEXTVAL для генерации значения последовательности CURRVAL сохраняет это значение до тех пор, пока не будет сгенерировано следующее значение. CURRVAL содержит только последнее сгенерированное значение.
69.How can gaps occur in the values of a sequence?
- Когда происходит откат
- Система вылетает
- Последовательность используется в другой таблице
- Все вышеперечисленное
Answer: D.
70.What is true about caching sequence values?
- Кеширование значений последовательности невозможно в Oracle
- Кеш заполняется, когда достигается максимальный предел последовательности.
- Кеширование запускается в первый раз при обращении к последовательности
- Ни один из вышеперечисленных
Answer: C. Если опция NOCACHE указана при создании последовательности, каждое число генерируется при получении запроса. Однако, если транзакции организации требуют большого количества последовательных номеров в течение сеанса, можно использовать параметр CACHE, чтобы Oracle 11g заранее сгенерировал набор значений и сохранил их в памяти сервера. Затем, когда пользователь запрашивает значение последовательности, назначается следующее доступное значение, при этом Oracle 11g не нужно генерировать номер. С другой стороны, если опция CACHE не указана, Oracle 11g принимает значение по умолчанию CACHE 20 и автоматически сохраняет 20 последовательных значений в памяти для доступа пользователей.
71.The following query for the sequence EMP_EMPID_SEQ is executed after a transaction which inserted five employee details.
Select emp_empID_seq.CURRVAL from dual;
Предположим, откат транзакции сотрудника. Что будет в результате вышеуказанного запроса?
- Значение последовательности в начале транзакции сотрудника
- NULL
- Значение последовательности в конце транзакции сотрудника
- Ни один из вышеперечисленных
Answer: C. На значения последовательности не влияет фиксация или откат. Если транзакция, использующая генератор последовательности, откатывается, значения последовательности теряются и не могут быть восстановлены.
72.Which of the following privileges are required to modify a sequence?
- CREATE OR REPLACE привилегия
- ALTER привилегия для последовательности
- ALTER TABLE привилегия
- UPDATE привилегия
Answer: B. Чтобы изменить последовательность, она должна быть в вашей собственной схеме, или у вас должна быть привилегия объекта ALTER для последовательности, или у вас должна быть системная привилегия ALTER ANY SEQUENCE.
73.What happens when a sequence is altered?
- Существующие целые числа, уже сгенерированные последовательностью, также изменяются.
- Затрагиваются только будущие целые числа
- Последовательность перестает кэшировать будущие целые числа
- Ни один из вышеперечисленных
Answer: B. Используя команду ALTER SEQUENCE, любые изменения применяются только к значениям, созданным после внесения изменений.
74.Suppose you need to drop a sequence. Which of the following commands will help?
ALTER SEQUENCE sequence_name START WITH NULL;
DROP sequence_name;
DROP SEQUENCE sequence_name;
- Ни один из вышеперечисленных
Answer: C. Команда DROP используется для удаления последовательности
75.Which of the following privileges will allow you to drop a sequence? (Choose the most appropriate answer)
- ИЗМЕНИТЬ ПОСЛЕДОВАТЕЛЬНОСТЬ
- ИЗМЕНИТЬ ТАБЛИЦУ
- ПОСЛЕДОВАТЕЛЬНОСТЬ УДАЛЕНИЯ
- УДАЛИТЬ ЛЮБУЮ ПОСЛЕДОВАТЕЛЬНОСТЬ
Answer: D. Чтобы отбросить последовательность, либо она должна быть в вашей собственной схеме, либо у вас должна быть системная привилегия DROP ANY SEQUENCE.
76.What is true about Indexes?
- Индексы создаются только вручную
- Индексы создаются только автоматически
- Оба а и Б
- Ни один из вышеперечисленных
Answer: D. Индексы можно создавать вручную, а также автоматически после определенных действий, таких как создание первичного ключа или ограничение unqiue.
77.Which of the following is used by an index to locate the data quickly?
- ROWNUM
- ROWID
- Sequence
- Ни один из вышеперечисленных
Answer: B. Индекс Oracle 11g - это объект базы данных, в котором хранится карта значений столбцов и ROWID соответствующих строк таблицы. ROWID - это физический адрес строки таблицы.
78.What happens when there is no index on a column of a table?
- Данные находятся быстро
- Есть полная развертка таблицы
- Таблица не может быть создана
- Таблица не может быть изменена
Answer: B.
79.What among the following is true about an Index?
- Индекс уменьшает дисковый ввод-вывод
- Индекс быстро находит данные
- Индексы логически и физически независимы от таблицы, которую они индексируют.
- Все вышеперечисленное
Answer: D.
80.What will happen if an index is dropped?
- Столбец, по которому создается индекс, тоже удаляется.
- Таблица, на которой создается индекс, тоже удаляется
- После создания индексы нельзя удалить
- Поскольку индексы являются логически и физически независимыми объектами, их можно удалить, не затрагивая другие объекты.
Answer: D. Индексы - это объекты, которые физически хранятся в схеме. Удаление индекса не влияет на другие объекты.
81.What happens when a table is dropped?
- Индексы остаются логически независимыми объектами.
- Индексы в таблице также удаляются
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: B.
82.How are indexes created automatically?
- Когда мы создаем таблицу
- Когда таблица изменена
- Когда ПЕРВИЧНЫЙ КЛЮЧ определен для столбца (или группы столбцов) таблицы
- Когда ограничение UNIQUE KEY определено в определении таблицы
Answer: C, D.
83.For which of the following objects, a synonym can be created?
- Только таблицы и представления
- Таблица, вид и последовательность
- Сохраненная процедура, функция или пакет
- Synonym
Answer: B, C, D. Объект схемы, для которого вы создаете синоним, может быть следующих типов: таблица или таблица объектов, представление или представление объекта, последовательность, хранимая процедура, функция или пакет, материализованное представление, объект схемы класса Java, определяемый пользователем тип объекта , Синоним
84. Which of the following can you use to reference a table owned by another user?
- INDEX
- TABLE
- SYNONYMS
- SEQUENCES
Answer: C. Синоним - это альтернативное имя или псевдоним для объекта базы данных.
85.What among of the following is an example of a Non-unique index?
- ОСНОВНОЙ КЛЮЧ
- УНИКАЛЬНЫЙ КЛЮЧ
- ВНЕШНИЙ КЛЮЧ
- Ни один из вышеперечисленных
Answer: C.
86.Which of the following is the main and basic type of an Index?
- Bitmap
- B-tree
- Unique
- Non-unique
Answer: A, B. Индекс B-tree (сбалансированное дерево) является наиболее распространенным индексом, используемым в Oracle. Вы можете создать индекс этого типа с помощью базового оператора CREATE INDEX. Индекс растрового изображения отличается по структуре и использованию от индекса B-дерева. Этот индекс полезен для улучшения запросов к столбцам с низкой избирательностью (низкая мощность или небольшое количество различных значений).
87.You need to speed up a query by creating an index on the FIRST_NAME of the EMPLOYEES table. Which of the following statements can you use? (Assume the table structure as shown)
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)
CREATE INDEX emp_first_name_idx ON employees (first_name);
CREATE INDEX emp_first_name_idx ON employees first_name;
ALTER INDEX emp_first_name_idx ON employees (first_name);
- Ни один из вышеперечисленных
Answer: A.
88.What does the UNIQUE keyword do while creating indexes?
- Он указывает, что значение столбца (столбцов), на котором создается индекс, должно быть уникальным.
- Вы не можете использовать ключевое слово UNIQUE при создании индексов
- Он указывает, что созданный индекс может использоваться только одной таблицей.
- Ни один из вышеперечисленных
Answer: A. Уникальный индекс обычно создается автоматически, когда для столбца определяется ограничение PRIMARY KEY или UNIQUE. Уникальные индексы также можно создать явно, включив ключевое слово UNIQUE в оператор CREATE INDEX.
89.What will happen when you specify the keyword BITMAP while creating an Index?
- Он создает индекс с битовой картой для каждого отдельного ключа.
- Он не создает индекс для каждой строки отдельно
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C.
90.You have queries written which are expected to retrieve less than 2% to 4% of rows. Which of the following can be applied on the relevant tables to achieve the query performance of such query? (Choose the best answer)
- Indexes
- Оператор множества UNION
- МИНУС установить оператор
- Ни один из вышеперечисленных
Answer: A. Индексы - лучший способ добиться производительности запросов. Объемные операции ввода-вывода можно сократить и упростить с помощью сканирования индекса.
91.In what scenarios can Indexes be useful?
- Если стол (ы) очень большой
- Если в столбце меньше значений
- Если столбец содержит большое количество значений NULL
- Если столбец имеет широкий диапазон значений
Answer: C, D.
92.The table EMPLOYEES is updated frequently. When can Indexes be created on this table? (Choose the most appropriate answer)
- Индексы не должны создаваться, если таблица часто обновляется
- Индексы должны быть созданы во время создания таблицы
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: A. Частые или массовые операции DML с таблицей с индексом добавляют накладные расходы на обслуживание сегмента индекса, что может повлиять на производительность операции DML.
93.Consider the following query and answer the following query. Assume that the EMPLOYEE_ID , DEPARTMENT_ID and FIRST_NAME columns of EMPLOYEES table are indexed. (Assume 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 first_name, last_name
FROM employees
WHERE comm IS NULL;
Помогут ли в этом случае существующие индексы, если в таблице EMPLOYEES 1 миллион строк?
- Yes
- No
- Это может помочь
- Ни один из вышеперечисленных
Answer: B. Индексы не используются, если предикаты запроса не содержат столбцов, по которым создается индекс.
94.Which of the following will remove an Index?
DELETE FROM index_name;
DROP INDEX index_name;
DROP INDEX;
- Ни один из вышеперечисленных
Answer: B. У вас должна быть привилегия DROP ANY INDEX, чтобы удалить индекс.