Вопросы по операторам DDL
1.What is the full form of DDL in Oracle DB?
- Язык удаления данных
- Язык определения данных
- Язык делегирования данных
- Язык фиктивных данных
Answer: B. DDL - это одна из категорий SQL, которая расшифровывается как язык определения данных. Другие типы SQL - это DML, DCL и TCL.
2.DDL statements are used for which of the following Oracle database objects?
- Tables
- Sub-queries
- Rows
- Columns
Answer: A. DDL содержит такие команды, как CREATE, ALTER и ANALYZE, которые используются для СОЗДАНИЯ ТАБЛИЦ, просмотра сохраненных подпрограмм и пакетов в схеме базы данных.
3.What is the basic unit of storage in Oracle Database that contains data?
- View
- Column
- Query
- Table
Answer: D. Таблица - это базовая единица физического хранения данных в базе данных Oracle.
4.Which of the below options best define a View?
- Это более короткая форма таблицы
- Это логическое представление подмножеств из одной или нескольких таблиц.
- В нем только одна строка и один столбец
- Ни один из вышеперечисленных
Answer: B. Представление - это запрос, который ведет себя как окно для форматирования данных, содержащихся в одной или нескольких таблицах. Представления не содержат никаких физических данных, а только запросы, которые создаются во время выполнения.
5. Which of the following are database objects?
- Table
- Sequence
- Synonym
- Все вышеперечисленное
Answer: D. Объекты, которые физически хранятся в схеме базы данных, являются объектами базы данных.
6. Which of the following database objects generate numeric values?
- Table
- View
- Index
- Sequence
Answer: D. Последовательность используется для генерации уникальных значений, начиная с определенного значения и увеличиваясь на указанный коэффициент. Последовательность может быть создана для генерации серии целых чисел. Значения, генерируемые последовательностью, могут быть сохранены в любой таблице. Последовательность создается командой CREATE SEQUENCE.
7.Which of the following database objects gives an alternative name to an object?
- Synonym
- Sequence
- View
- Index
Answer: A. Синоним обеспечивает постоянный псевдоним для объекта базы данных. Публичный синоним доступен любому пользователю базы данных. Частный синоним доступен только тому пользователю, который его создал. Синоним создается с помощью команды CREATE SYNONYM. Синоним удаляется с помощью команды DROP SYNONYM. Только пользователь с правами администратора базы данных может удалить общедоступный синоним.
8.Which of the following database objects improves the performance of some queries?
- Table
- Synonym
- View
- Index
Answer: D.
9. When a table can be created?
- Когда база данных не используется ни одним пользователем
- Когда база данных создается заново
- Его можно создать в любое время, даже когда пользователь использует базу данных.
- Ни один из вышеперечисленных
Answer: C. Можно создать индекс, чтобы ускорить процесс запроса. При наличии индексов операции DML всегда выполняются медленнее. Oracle 11g автоматически создает индекс для ограничений PRIMARY KEY и UNIQUE. Явный индекс создается с помощью команды CREATE INDEX. Индекс может использоваться Oracle 11g автоматически, если критерий запроса или операция сортировки основаны на столбце или выражении, используемом для создания индекса.
10. What is true about a table?
- Размер таблицы указывать не обязательно.
- Размер каждой таблицы одинаковый
- Таблицу можно изменить онлайн
- Ни один из вышеперечисленных
Answer: A, C.
11. A table named 123_A is created for storing the number of employees in an organization. What is wrong in the name of the table?
- Имя таблицы не может начинаться с цифры
- В этом названии нет ничего плохого.
- Вы не можете использовать подчеркивание при названии таблицы
- Ни один из вышеперечисленных
Answer: A. Согласно соглашениям об именах объектов, имя таблицы должно начинаться с алфавита.
12. What is the range of number of letters a table name can have?
- 1-20 символов
- 1-10 символов
- 1-30 символов
- 1-50 символов
Answer: C. Имя таблицы не может превышать 30 символов.
13 Which of the following characters can be used to name a table?
- От А до Я
- от а до я
- От 0 до 9
- Все вышеперечисленное
Answer: D. Согласно стандартному соглашению об именах в Oracle, имя объекта в любом случае может содержать алфавиты. Обязательно первое место для букв, а остальное может быть сочетание букв и цифр.
14. Which of the following special characters can be used to name a table?
- @
- #
- $
- _ (нижнее подчеркивание)
Answer: B, C, D. Никакие другие специальные символы, кроме (#, $, _), не допускаются при именовании таблицы. Не рекомендуется использовать специальные символы в названии таблицы.
15. What is true about the name of a table?
- Таблица может иметь имя, которое используется другим объектом, принадлежащим тому же пользователю.
- Последовательность и таблица могут иметь одинаковые имена
- Вид и таблица могут иметь одно и то же имя
- Имя таблицы не должно дублировать имя другого объекта, принадлежащего тому же пользователю.
Answer: D. В силу пространства имен имя таблицы не может быть таким же, как у любых других объектов схемы. Объекты схемы, которые используют одно и то же пространство имен, включают таблицы, представления, последовательности, частные синонимы, хранимые процедуры, хранимые функции, пакеты, материализованные представления и определяемые пользователем типы.
16.You create a table and name it as COUNT. What will be the outcome of CREATE TABLE script?
- Таблица не будет создана
- Таблица будет создана, и к имени COUNT_ будет автоматически добавлено подчеркивание.
- Будет выдана ошибка ORA
- Таблица COUNT будет создана без ошибок.
Answer: A, C. Вы не можете создать таблицу с таким же именем, как зарезервированное слово Oracle Server.
17. You create a table using quoted identifiers ' '. How will you refer this table?
- 'table_name'
- "table_name"
- Либо A, либо B
- Ни один из вышеперечисленных
Answer: B. Если таблица создается с именем, имеющим заключенный в кавычки идентификатор, к ней необходимо обращаться с использованием двойных кавычек. Использование идентификаторов в кавычках не рекомендуется. Цитированные идентификаторы чувствительны к регистру
18. You create a table named EMPLOYEES. What among the following is possible?
- Его можно назвать СОТРУДНИКАМИ
- Его можно назвать EMPLoyees
- Его можно назвать служащим
- Все вышеперечисленное
Answer: D. Имена объектов без кавычек в Oracle не чувствительны к регистру.
19. What among the following are the pre-requisites for creating a table?
- CREATE TABLE привилегия
- Место для хранения
- Данные в таблице
- Ни один из вышеперечисленных
Answer: A, B. Пользователь должен обладать привилегией CREATE TABLE и иметь достаточно места для выделения начального экстента сегменту таблицы.
20. What is the syntax for creating a table?
- CREATE TABLE [schema.] Table (тип данных столбца [DEFAULT expr] [, ..]);
- СОЗДАТЬ ТАБЛИЦУ В [схему.] Таблицу (тип данных столбца [DEFAULT expr] [, ..]);
- CREATE TABLE VALUES [schema.] Table (тип данных столбца [DEFAULT expr] [, ..]);
- Ни один из вышеперечисленных
Answer: A.
21. Pick the element which you must specify while creating a table.
- Название столбца
- Тип данных столбца
- Размер столбца
- Все вышеперечисленное
Answer: D. В таблице должен быть не менее одного столбца, спецификация типа данных и точность (если требуется).
22. A user named "Kevin" wants to access a table which is owned by another user named "Jonathan". Which of the following will work for Kevin?
- Выберите * от Kevin.employees;
- Выберите * от jonathan.employees;
- Либо A, либо B
- Ни один из вышеперечисленных
Answer: B.
23. What is true about a schema?
- Схема принадлежит пользователю базы данных и имеет то же имя, что и этот пользователь.
- Каждому пользователю принадлежит одна схема
- Объекты схемы включают ссылки на базу данных
- Все вышеперечисленное
Answer: D. Пространство пользователя в базе данных называется схемой. Схема содержит объекты, которые принадлежат пользователю или к которым он имеет доступ. У каждого пользователя может быть своя собственная схема.
24. What among the following is true about tables?
- Значение по умолчанию присваивается таблице
- Значение по умолчанию может быть присвоено столбцу таблицы во время оператора INSERT.
- Либо A, либо B
- Ни один из вышеперечисленных
Answer: B. Значение по умолчанию может быть указано для столбца во время определения с помощью ключевого слова DEFAULT.
25. Which of the following can be used with the DEFAULT option while creating a table?
- Strings
- Expressions
- Функции SQL
- Все вышеперечисленное
Answer: D. Значение по умолчанию для столбца может быть литералом или производной с использованием функции SQL.
26. Which of the following command is used to see the structure of a table?
- UPDATE
- SHOW
- DESCRIBE
- SPOOL
Answer: C. DESCRIBE - это команда SQL * Plus для вывода списка структуры таблицы.
27.What is the limit of CHECK constraints on a column?
- Нет ограничений
- 1
- 2
- 4
Answer: A. Oracle не накладывает ограничений на проверочные ограничения для столбца.
28. Which of the following commands will drop table employees? (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)
DROP employees
DROP TABLE employees
TRUNCATE employees
- Ни один из вышеперечисленных
Answer: B.
29. What is true about a namespace?
- Это группа типов объектов
- В пространстве имен все имена объектов должны однозначно идентифицироваться схемой и именем.
- Один и тот же тип объектов в разных пространствах имен может иметь одно и то же имя.
- Все вышеперечисленное
Answer: D. Пространство имен определяет группу типов объектов, внутри которых все имена должны быть однозначно идентифицированы схемой и именем. Объекты в разных пространствах имен могут иметь одно и то же имя.
30. Which of the following object types share the same namespace?
- Synonyms
- Table
- Views
- Все вышеперечисленное
Answer: D.
31. What among the following is true about a table and an index?
- Индекс и таблица могут иметь одно и то же имя в схеме.
- Индекс и таблица в схеме не могут иметь одно и то же имя.
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: A. Поскольку индекс и ограничения используют одно и то же пространство имен, таблица и индекс могут иметь одно и то же имя.
32. What is true about creating a table?
- При создании таблицы каждому столбцу должен быть присвоен тип данных
- Присвоение типа данных столбцам не обязательно
- Тип данных должен быть назначен таблице, а не столбцу.
- Ни один из вышеперечисленных
Answer: A. Каждый столбец должен обладать поведенческими атрибутами, такими как типы данных и точность, чтобы построить структуру таблицы.
33. Suppose you create a table as shown below:
CREATE TABLE employees
(emp_id NUMBER(4),
last_name VARCHAR2 (20)
);
Сколько места Oracle выделит столбцу LAST_NAME?
- Если строк нет, Oracle не выделяет место для столбца last_name
- Если строки заполнены, Oracle выделит неограниченное пространство для столбца last_name
- Ни A, ни B
- Ни один из вышеперечисленных вариантов
Answer: A.
34. What is the range of size that a VARCHAR2 data type can take?
- От 1 байта до 2 байтов
- От 1 байта до 2000 байтов
- От 1 байта до 4000 байтов
- Ни один из вышеперечисленных
Answer: C. До Oracle 11g Release 2 строковый тип данных VARCHAR2 может содержать максимум 4000 байтов.
35.What is the range of size that a CHAR data type can take?
- От 1 байта до 2 байтов
- От 1 байта до 2000 байтов
- От 1 байта до 4000 байтов
- От 1 байта до 3000 байтов
Answer: B. До Oracle 11g Release 2 строковый тип данных CHAR может содержать максимум 2000 байтов.
36. What is true about the CHAR data type?
- Если данные не соответствуют длине столбца, они будут заменены значениями NULL.
- Если данные не соответствуют длине столбца, они будут дополнены пробелами.
- Обязательно иметь данные того же размера, что и размер CHAR, иначе это приведет к ошибке ORA.
- Ни один из вышеперечисленных
Answer: B. CHAR обеспечивает хранение значения фиксированной длины, в то время как VARCHAR2 является гибким. Если в столбец типа CHAR вставлены данные, длина которых меньше точности CHAR, оставшаяся длина будет дополнена значением столбца.
37. Which of the following is a data type for variable length binary data?
- VARCHAR
- VARCHAR2
- RAW
- NVARCHAR2
Answer: C.
38. What is the precision allowed for the NUMBER data type?
- От 1 до 20
- От 1 до 4K
- От 1 до 30
- От 1 до 38 цифр
Answer: D. До Oracle 11g Release 2 максимальная точность первичного типа данных NUMBER составляла 38 цифр.
39. What is the scale allowed for the NUMBER data type?
- От 1 до 20
- От -84 до 100
- От -84 до 127
- Ни один из вышеперечисленных
Answer: C.
40. Which of the following are the data types for date and time data?
- TIMESTAMP
- ИНТЕРВАЛ ДЕНЬ ДО ВТОРОЙ
- TIMESTAMP С МЕСТНЫМ ЧАСОМ
- Все вышеперечисленное
Answer: D.
41. Which of the following data types are for large objects?
- CLOB
- BLOB
- RAW
- Все вышеперечисленное
Answer: A, B. Типы данных LOB в SQL - это BLOB, CLOB и BFILE.
42. What will happen if the inserted value is of a smaller length as defined for a VARCHAR2 data type column?
- Это вызовет ошибку ORA
- Он будет успешно вставлен, и значение займет столько места, сколько ему нужно.
- Он будет вставлен, а оставшееся пространство будет заполнено пробелами
- Ни один из вышеперечисленных
Answer: B. VARCHAR2 содержит символьные данные переменной длины.
43. What does NUMBER (8, 2) in oracle mean?
- Это означает, что всего 8 цифр, 6 цифр до десятичной и 2 после десятичной.
- Это означает, что всего 10 цифр, 8 цифр перед десятичной и 2 после десятичной.
- Это означает, что перед десятичной запятой стоят 2 цифры, а после десятичной точки - 8.
- Ни один из вышеперечисленных
Answer: A. Буква p обозначает точность, общее количество цифр слева и справа от десятичной позиции, максимум до 38 цифр; s, или шкала, указывает количество позиций справа от десятичной дроби. Пример: NUMBER (7, 2) может хранить числовое значение до 99999.99. Если точность или масштаб не указаны, точность столбца по умолчанию составляет 38 цифр.
44. Which of the following queries will create a table with no rows in it?
CREATE TABLE emp AS SELECT 0 from dual;
CREATE TABLE emp AS SELECT * from employees where 1=1;
CREATE TABLE emp AS SELECT * from employees where 1=2;
CREATE TABLE emp AS SELECT 0 from employees;
Answer: C. Операция прямого пути CTAS (CREATE TABLE .. AS SELECT ..) может использоваться для копирования структуры существующей таблицы без копирования данных.
45. Which of the following statements would add a column to a table already created?
ALTER TABLE table_name add column (job varchar2(20));
ALTER TABLE table_name add job varchar2(20);
ALTER TABLE table_name add (job varchar2(20));
ALTER TABLE table_name add column (job);
Answer: C. Команда ALTER TABLE позволяет пользователю добавить новый столбец в таблицу. Те же правила для создания столбца в новой таблице применяются к добавлению столбца в существующую таблицу. Новый столбец должен определяться именем столбца и типом данных ( и ширину, если применимо). Также может быть присвоено значение по умолчанию. Разница в том, что новый столбец добавляется в конец существующей таблицы - это будет последний столбец.
46. Which of the following statements will modify the data type of an already existing column?
ALTER TABLE table_name MODIFY (job varchar2(10) );
ALTER TABLE table_name MODIFY job varchar2(10);
ALTER TABLE table_name MODIFY column (job varchar2(10) );
ALTER TABLE table_name MODIFY (job varchar2(10) );
Answer: A. ALTER TABLE..MODIFY используется для изменения определения столбца в таблице. Допустимые изменения: повышение точности столбца, изменение типа данных в семействе типов данных или изменение значения столбца по умолчанию.
47. Which of the following statements will remove a column from the table?
ALTER TABLE table_name DROP (job varchar2(10) );
ALTER TABLE table table_name DROP COLUMN (job varchar2(10) );
ALTER TABLE table table_name DROP COLUMN (job);
ALTER TABLE table_name MODIFY (job varchar2(10) );
Answer: C. ALTER TABLE..DROP COLUMN можно использовать для удаления столбца из таблицы.
48. Which of the following will rename the column emp_id to empno?
ALTER TABLE employees RENAME column emp_id to empno;
ALTER TABLE employees RENAME emp_id to empno;
ALTER TABLE employees RENAME column emp_id to empno;
- Ни один из вышеперечисленных;
Answer: A. ALTER TABLE..RENAME можно использовать для переименования существующего столбца в таблице.
49. You need to mark the table employees as read only. Which of the following statements will you execute to get the required result?
ALTER TABLE employees set READ;
ALTER TABLE employees READ ONLY;
ALTER TABLE employees READ_ONLY;
ALTER TABLE employees set READ ONLY;
Answer: B. Таблицу можно пометить только для чтения, чтобы сделать ее пассивной по отношению к операторам DML и DDL. Функция только для чтения появилась в Oracle 11g.
50. What among the following is true about DDL statements?
- Команды DDL становятся частью текущей транзакции
- Команды DDL автоматически фиксируются и завершают текущую активную транзакцию
- Если команда DDL завершается неудачно, текущая транзакция все еще фиксируется
- Если команда DDL завершается неудачно, текущая транзакция откатывается.
Answer: B. Команды DDL автоматически фиксируются, только если они успешно выполняются без ошибок. Если команда DDL завершается неудачно, текущая транзакция все еще активна в сеансе и не фиксируется в базе данных.
51. What happens if there is an active transaction against a table on which a DDL is issued?
- Откат транзакции
- Транзакция зафиксирована и прекращена
- Оба а и Б
- Ни один из вышеперечисленных
Answer: B.
52. Which of the following commands will remove unused columns in an SQL statement?
ALTER TABLE tablename DROP COLUMN column_name;
ALTER TABLE tablename DROP unused columns;
ALTER TABLE tablename set unused column;
ALTER TABLE tablename DROP columns;
Answer: C. Команда SET UNUSED удаляет из таблицы только неиспользуемые столбцы и выполняется быстрее.
53. What happens when a table which is marked Read Only is attempted for drop?
- Это вызовет ошибку
- Он больше не будет оставаться только для чтения, но его также нельзя будет отбросить
- Сбросится без ошибок
- Он останется нетронутым
Answer: C. Команда DROP влияет на определение словаря данных таблиц, которые не предназначены только для чтения, и, следовательно, возможно удаление.
Consider the following statement and answer the questions 54 and 55 that follow:
CREATE TABLE departments
(dept_id NUMBER (2),
dept_name VARCHAR2(14),
create_date DATE DEFAULT SYSDATE);
54. What will happen if the DEFAULT clause specification is removed from the statement?
- Сценарий выдаст ошибку, потому что столбцы DATE должны быть указаны со значением по умолчанию.
- Столбцу будет присвоено значение по умолчанию, созданное системой.
- Таблица будет создана без значения по умолчанию для столбца CREATE_DATE
- Ни один из вышеперечисленных
Answer: C.
55.What is true about the above statement?
- Он автоматически зафиксирует транзакцию в сеансе
- В схеме будет создана таблица DEPARTMENTS.
- Он установит значение по умолчанию для столбца CREATE_DATE
- Ни один из вышеперечисленных
Answer: A, B, C.
56. Up to which limit can a BLOB data type column hold values?
- 1 КБ
- 2 ГБ
- 4ГБ
- 3 КБ
Answer: C. Согласно Oracle 11g максимальный размер данных, размещаемых в BLOB, может составлять 4 ГБ.
57.What is the difference between CLOB and BLOB data types? (Choose the most appropriate answer)
- CLOB - символьные данные, BLOB - двоичные данные
- CLOB - это символьные данные размером до 2 ГБ, BLOB - это двоичные данные размером до 4 ГБ.
- CLOB - это символьные данные размером до 4 ГБ, BLOB - это двоичные данные размером до 4 ГБ.
- Ни один из вышеперечисленных
Answer: C. CLOB - это большой символьный объект, который используется для хранения символьных файлов, таких как PDF, документы и текстовые файлы, а BLOB - это двоичный LOB, используемый для хранения файлов мультимедиа.
58.What among the following is a ROWID?
- Это порядковый номер, присвоенный набору строк, начинающихся с 1.
- Это буквенно-цифровой адрес, присвоенный строке в таблице.
- Оба а и Б
- Ни один из вышеперечисленных
Answer: B. Это система base-64, представляющая уникальный адрес строки в своей таблице.
59.What is the data type used for storing Binary data stored in an external file (up to 4 GB)?
- BLOB
- CLOB
- CFILE
- BFILE
Answer: D. BFILE - это внешний тип LOB, который используется для ссылки на внешние медиа-файлы. Внутренние типы LOB - это BLOB и CLOB, которые используются для больших двоичных файлов и больших символьных файлов, хранящихся в базе данных.
60. What is true about a table created with a sub-query?
- Столбец типа данных VARCHAR2 не копируется, когда таблица создается с помощью подзапроса
- Столбец типа данных CLOB не копируется, когда таблица создается с помощью подзапроса.
- Столбец LONG не копируется, когда таблица создается с помощью подзапроса
- Ни один из вышеперечисленных
Answer: C. Метод CTAS для создания таблицы не копирует столбец LONG.
61. Which of the following data types cannot be used with a GROUP BY and an ORDER BY clause?
- CLOB
- VARCHAR2
- CHAR
- LONG
Answer: D. Типы данных LONG нельзя использовать в предложениях GROUP BY и ORDER BY.
62. How many LONG columns can a table contain?
- None
- Максимум 2
- Минимум 2
- Единственный
Answer: D. Таблица может содержать максимум один столбец типа LONG.
63.Which of the following data types cannot be constrained in SQL?
- VARCHAR2
- LONG
- CHAR
- DATE
Answer: B. Ограничения не могут быть созданы для столбцов типа LONG.
64. Which of the following data types can you use if you want a date with fractional seconds?
- DATE
- VARCHAR2
- TIMESTAMP
- Ни один из вышеперечисленных
Answer: C. Тип данных TIMESTAMP предоставляет дополнительную точную информацию о значениях даты. Он предоставляет информацию о долях секунды и часовом поясе.
65. You need to store an interval of days, hours, minutes and seconds in a column. Which of the data type would help?
- TIMESTAMP
- ИНТЕРВАЛ К МЕСЯЦУ
- ИНТЕРВАЛ ДЕНЬ ДО ВТОРОЙ
- Ни один из вышеперечисленных
Answer: C.
66.You need to find how many employees were hired in June, 2011 and June, 2012. Which of the following data types will help?
- ИНТЕРВАЛ ДЕНЬ ДО ВТОРОЙ
- TIMESTAMP
- DATE
- ИНТЕРВАЛ К МЕСЯЦУ
Answer: D.
67. What is true about constraints?
- Они обеспечивают соблюдение правил на уровне строк
- Они обеспечивают соблюдение правил на уровне таблицы
- При создании таблицы обязательно должны быть созданы ограничения.
- Ни один из вышеперечисленных
Answer: B. Ограничение - это правило, применяемое к данным, добавляемым в таблицу. Он представляет бизнес-правила, политики или процедуры. Данные, нарушающие ограничение, не добавляются в таблицу. Ограничение может быть включено во время создания таблицы как часть команды CREATE TABLE или добавлено в существующую таблицу с помощью команды ALTER TABLE. Ограничение на основе составных столбцов (более одного столбца) должно быть создано с использованием подхода на уровне таблицы.
68. How are constraints helpful?
- Они ограничивают емкость хранения таблицы и, следовательно, экономят место в БД.
- Они предотвращают изменение таблицы
- Они предотвращают удаление таблицы, если есть зависимости
- Ни один из вышеперечисленных
Answer: C. Ограничение - это правило, применяемое к данным, добавляемым в таблицу. Оно представляет бизнес-правила, политики или процедуры. Данные, нарушающие ограничение, не добавляются в таблицу.
69.A RAW data type column can store variable-length binary strings up to what value?
- 10 ГБ
- 1 ТБ
- 2 ГБ
- 4ГБ
Answer: C.
70. Which of the following are valid constraints in Oracle?
- INDEX
- GENERAL
- UNIQUE
- ОСНОВНОЙ КЛЮЧ
Answer: C, D. Ограничение NOT NULL может быть создано только на уровне столбцов. Ограничение PRIMARY KEY не допускает дублирования или NULL значений в указанном столбце. В таблице разрешено только одно ограничение PRIMARY KEY. Ограничение FOREIGN KEY требует, чтобы запись столбца соответствовала записи столбца, на которую указывает ссылка в таблице, или была ПУСТО (NULL). Ограничение UNIQUE похоже на ограничение PRIMARY KEY, за исключением того, что оно позволяет сохранять значения NULL в указанном столбце. Ограничение CHECK гарантирует, что данные соответствуют заданному условию, прежде чем они будут добавлены в таблицу.
71. Which of the below DML operations consider constraints on a column?
- INSERT
- UNION
- DELETE
- UPDATE
Answer: A, C, D. Все операции DML подчиняются ограничениям на столбцы таблицы.
72. When can a constraint be created?
- При создании таблицы
- После создания таблицы
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C. Ограничение может быть включено во время создания таблицы как часть команды CREATE TABLE или добавлено к существующей таблице с помощью команды ALTER TABLE.
73 Where are constraints stored?
- В SGA
- В таблице
- В словаре данных
- Ни один из вышеперечисленных
Answer: C.
74. You create a constraint but do not name it. What will be the default name given to the constraint?
- SYS_Cn
- SYS_constraint
- SYS_Const
- SYS_C0
Answer: A. По умолчанию Oracle дает ограничениям SYS_Cn общее имя, где n - целое число, чтобы имя ограничения было уникальным.
75. What is the functional difference between a column-level constraint and a table-level constraint?
- Ограничение на уровне столбца применяется ко всем столбцам таблицы
- Ограничение на уровне таблицы применяется ко всем столбцам таблицы
- Оба они функционально одинаковы, отличается только синтаксис.
- Ни один из вышеперечисленных
Answer: C. Функционально ограничения уровня таблицы и ограничения уровня столбца работают аналогично. Составные ограничения могут быть определены только на уровне таблицы.
76. What is true about column-level constraints?
- Их можно создать до создания таблицы.
- Их можно создать до определения столбца.
- Они включаются при определении столбца
- Ни один из вышеперечисленных
Answer: C. Ограничения уровня столбца определяются вместе со спецификацией столбца.
77. What is true about NOT NULL constraints in SQL?
- Их следует определять на уровне таблицы.
- Их следует определять на уровне столбца.
- Их следует определять только в одном столбце
- Их следует определять только в одной строке
Answer: B. Ограничение NOT NULL может быть создано только на уровне столбцов.
Consider the following statement and answer the questions 78 and 79 that follow:
CREATE TABLE employees (
emp_id NUMBER (6) CONSTRAINT emp_emp_id_PK PRIMARY KEY,
first_name VARCHAR2(20),
last_name VARCHAR2(20),
hire_date DATE
);
78.Which type of constraint is created in the above statement?
- Ограничение уровня столбца
- Ограничение на уровне таблицы
- Именованное ограничение
- Ограничение спецификации
Answer: A. Ограничение уровня столбца создается вместе с определением столбца.
79. What modification can be made to the above statement to give it a table level constraint?
- ОГРАНИЧЕНИЕ emp_emp_id_PK ПЕРВИЧНЫЙ КЛЮЧ
- ОГРАНИЧЕНИЕ emp_emp_id_PK ПЕРВИЧНЫЙ КЛЮЧ (EMP_ID)
- ОГРАНИЧЕНИЕ emp_emp_id_PK EMP_ID ПЕРВИЧНЫЙ КЛЮЧ
- ПЕРВИЧНЫЙ КЛЮЧ ОГРАНИЧЕНИЯ emp_emp_id_PK
Answer: B.
80. What is true about PRIMARY KEY constraint?
- Он неявно применяет ограничение NOT NULL к столбцу, для которого оно определено.
- Он неявно применяет ограничение UNIQUE KEY к столбцу, для которого оно определено.
- Он неявно применяет ограничение CHECK к столбцу, для которого оно определено.
- Он неявно применяет ограничение DEFAULT к столбцу, для которого оно определено.
Answer: A. Ограничение PRIMARY KEY не допускает дублирования или NULL значений в указанном столбце. В таблице разрешено только одно ограничение PRIMARY KEY.
81. What among the following is true regarding a UNIQUE KEY constraint?
- Ограничение UNIQUE KEY и ограничение PRIMARY KEY одинаковы
- Ограничение UNIQUE KEY допускает значения NULL, если для столбца (столбцов) не задано значение NOT NULL.
- У нас могут быть две идентичные строки, если для столбца определено ограничение UNIQUE KEY.
- Ни один из вышеперечисленных
Answer: B. Ограничение UNIQUE похоже на ограничение PRIMARY KEY, за исключением того, что оно позволяет сохранять значения NULL в указанном столбце.
Consider the following statement and answer the questions 82 and 83 that follow:
CREATE TABLE employees (
emp_id NUMBER (6)
first_name VARCHAR2(20),
last_name VARCHAR2(20),
job VARCHAR2(20),
hire_date DATE
CONSTRAINT emp_job_UK UNIQUE (job));
82. Which of the below statements interpret the above CREATE TABLE script?
- В этой таблице не может быть двух одинаковых идентификаторов вакансий.
- В этой таблице может быть два или более одинаковых идентификатора вакансии.
- Эта таблица может иметь значения NULL в столбце JOB
- Ни один из вышеперечисленных
Answer: A, C. Ограничение UNIQUE для столбца JOB ограничивает повторяющееся значение, но допускает значения NULL.
83. If the constraint emp_job_UK is modified as emp_job_PK PRIMARY KEY (job), what will be outcome?
- Это изменение может произойти, только если в столбце JOB нет значения NULL.
- Это изменение может произойти без каких-либо ограничений
- Это изменение изменит значения столбца JOB.
- Ни один из вышеперечисленных
Answer: A.
84. What is true about the UNIQUE key constraint?
- Индекс уникального ключа неявно создается, когда для столбца определено ограничение UNIQUE.
- Ограничение PRIMARY KEY неявно создается, когда ограничение UNIQUE определено для столбца.
- Ограничение NOT NULL неявно создается, когда ограничение UNIQUE определено для столбца.
- Ни один из вышеперечисленных
Answer: A. Когда на таблицу накладывается ограничение уникальности, Oracle внутренне создает индекс уникального ключа для столбца, чтобы ограничить дублирование значений.
85. Which of the following is true about indexes?
- Если для таблицы выполняется инструкция UPDATE, индексы также необходимо обновить вручную.
- Если для таблицы выполняется инструкция DELETE, индексы также необходимо удалить вручную.
- Когда таблица удаляется, индексы удаляются автоматически
- Если для таблицы выполняется инструкция UPDATE, соответствующие индексы также обновляются.
Answer: C, D.
86.Which of the following CREATE TABLE statements is valid?
CREATE TABLE EMPLOYEES (emp_id NUMBER (2) PRIMARY KEY, first_name VARCHAR(20), last_name VARCHAR(20), hire_date DATE NOT NULL);
CREATE TABLE EMPLOYEES (emp_id NUMBER (2) PRIMARY KEY NOT NULL, first_name VARCHAR(20), last_name VARCHAR(20), hire_date DATE NOT NULL PRIMARY KEY);
CREATE TABLE EMPLOYEES (emp_id NUMBER (2) PRIMARY KEY, first_name VARCHAR(20), last_name VARCHAR(20), hire_date DATE NOT NULL UNIQUE);
CREATE TABLE EMPLOYEES (emp_id NUMBER (2), first_name VARCHAR(20), last_name VARCHAR(20), hire_date DATE NOT NULL, CONSTRAINT emp_emp_id_PK PRIMARY KEY (emp_id));
Answer: A, C, D. Все скрипты CREATE TABLE действительны.
87. How many PRIMARY KEY constraints can a table have?
- 0
- Unlimited
- 2
- 1
Answer: D. Таблица может иметь один и только один первичный ключ.
88. You want to put a CHECK constraint on the EMP_ID such that it should be equal to the current value of a Sequence through which it is getting its values. Which of the following statements will help you achieve this?
- Emp_id NUMBER (10) CONSTRAINT emp_emp_id_chk CHECK (emp_id = EMPNO.CURRVAL);
- Emp_id NUMBER (10) CONSTRAINT emp_emp_id_chk CHECK (emp_id = EMPNO.NEXTVAL);
- Emp_id NUMBER (10) CONSTRAINT emp_emp_id_chk CHECK (EMPNO.CURRVAL);
- Ни один из вышеперечисленных
Answer: D. Вы не можете использовать псевдостолбцы CURRVAL, NEXTVAL, LEVEL и ROWNUM в ограничении CHECK.
89. Which of the following commands will help in converting the foreign key values to NULL?
- НА КАСКАДЕ УДАЛЕНИЯ
- ПРИ УДАЛЕНИИ УСТАНОВИТЬ NULL
- CASCADE
- REFERENCES
Answer: B.
90. You need to add a constraint to the EMPLOYEES table which restricts the addition of those employees who have salaries less than 10000. Which of the following commands will give you the required results?
ALTER TABLE employees ADD CONSTRAINT emp_emp_sal_CHECK CHECK (salary >= 10000);
ALTER TABLE employees ADD CHECK CONSTRAINT emp_emp_sal_CHECK (salary>10000);
ALTER TABLE employees ADD CONSTRAINT CHECK emp_emp_sal_CHECK (salary = 10000);
ALTER TABLE employees ADD CONSTRAINT emp_emp_sal_CHECK (salary < 10000);
Answer: A.
91. You need to add a constraint to the EMPLOYEES table which imposes a restriction that the HIRE_DATE for all the employees should be equal to SYSDATE-7. Which of the following statements will give you the required results?
ALTER TABLE employees ADD CHECK CONSTRAINT emp_emp_sal_CHECK ( to_char(hire_date,'DD-MON-YY') = SYSDATE -7);
ALTER TABLE employees ADD CONSTRAINT CHECK emp_emp_sal_CHECK ( to_char(hire_date,'DD-MON-YY') = SYSDATE -7);
ALTER TABLE employees ADD emp_emp_sal_CHECK CHECK ( to_char(hire_date,'DD-MON-YY') = SYSDATE -7);
- Ни один из вышеперечисленных
Answer: D. Вы не можете использовать функции SYSDATE, UID, USER и USERENV в ограничении CHECK.
Consider the following query and answer the questions 92 to 94 that follow:
CREATE TABLE EMPLOYEES
(emp_id NUMBER (2),
first_name VARCHAR(20),
last_name VARCHAR(20),
dept_id NUMBER (10),
hire_date DATE DEFAULT SYSDATE
CONSTRAINT emp_emp_id_PK PRIMARY KEY (emp_id, hire_date)
CONSTRAINT emp_dept_FK FOREIGN KEY (dept_id)
REFERENCES departments (dept_id)
);
92. Which of the below statements interpret the CREATE TABLE script?
- Ограничение FOREIGN KEY определяется на уровне таблицы в столбце DEPT_ID.
- Определенное ограничение FOREIGN KEY ссылается на DEPT_ID из таблицы DEPARTMENTS.
- Оба а и Б
- Ни один из вышеперечисленных
Answer: C. Ключевые слова FOREIGN KEY и REFERENCES используются, когда мы определяем ограничение FOREIGN KEY для ссылочной целостности.
93. You need to delete all the dependent rows in DEPARTMENTS table when you delete the EMPLOYEES table. Which of the following command will solve the purpose? (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)
- ПРИ УДАЛЕНИИ УСТАНОВИТЬ NULL
- НА КАСКАДЕ УДАЛЕНИЯ
- УДАЛИТЬ ВСЕ
- ДЛЯ ОБНОВЛЕНИЯ
Answer: B. Если ON DELETE CASCADE включен в определение ограничения и запись удаляется из родительской таблицы, любые соответствующие записи в дочерней таблице также удаляются автоматически.
94. The EMPLOYEES table as shown below, has 5 employees who work in department 10. An executive from admin department issues the below query.
DELETE FROM departments
WHERE dept_id = 10;
Каков будет результат этого запроса? (Предположим, что структура таблицы показана на рисунке)
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)
- Ошибка ограничения целостности
- Успешное исполнение
- Ни A, ни B
- Ни один из вышеперечисленных
Answer: A. DEPT_ID из DEPARTMENTS - это внешний ключ в таблице EMPLOYEES, и в отделе 10 есть сотрудники, поэтому значение не может быть удалено из родительской таблицы, пока не будет найдена дочерняя запись.