Использование операторов DDL

Использование операторов DDL для создания таблиц и управления ими

Схема - это совокупность нескольких объектов базы данных, которые называются объектами схемы. Эти объекты имеют прямой доступ к схеме-владельцу. В таблице ниже перечислены объекты схемы.

  • Таблица - для хранения данных

  • Просмотр - для проецирования данных в желаемом формате из одной или нескольких таблиц.

  • Последовательность - для генерации числовых значений

  • Индекс - для повышения производительности запросов к таблицам

  • Синоним - альтернативное название объекта

Одним из первых шагов при создании базы данных является создание таблиц, в которых будут храниться данные организации. Дизайн базы данных включает определение системных требований пользователей для различных организационных систем, таких как ввод заказов, управление запасами и дебиторская задолженность. Независимо от размера и сложности базы данных каждая база данных состоит из таблиц.

Создание таблицы

Чтобы создать таблицу в базе данных, администратор базы данных должен иметь под рукой определенную информацию - имя таблицы, имя столбца, типы данных столбца и размеры столбцов. Всю эту информацию можно позже изменить с помощью команд DDL.

Соглашения об именах таблиц -

  • Имя, которое вы выбираете для стола, должно соответствовать этим стандартным правилам:

  • Имя должно начинаться с буквы AZ или az.

  • Может содержать числа и символы подчеркивания

  • Может быть в ВЕРХНЕМ или строчных

  • Может быть длиной до 30 символов

  • Невозможно использовать то же имя другого существующего объекта в вашей схеме

  • Не должно быть зарезервированным словом SQL

Следуя приведенным выше рекомендациям, EMP85 может быть допустимым именем таблицы, но 85EMP - нет. Аналогично, UPDATE не может быть выбран в качестве имени таблицы, поскольку это зарезервированное ключевое слово SQL.

Оператор CREATE TABLE

CREATE TABLE - это оператор DDL, который используется для создания таблиц в базе данных. Таблица создается сразу после выполнения сценария CREATE TABLE и готова к хранению данных. Пользователь должен иметь системную привилегию CREATE TABLE для создания таблица в своей собственной схеме. Но для создания таблицы в схеме любого пользователя пользователь должен иметь схему CREATE ANY TABLE.

Вот синтаксис основного оператора CREATE TABLE. Может быть много дополнительных предложений для явного предоставления спецификаций хранения или значений сегментов.

CREATE TABLE [schema.]table 
          ( { column datatype [DEFAULT expr] [column_constraint] ... 
            | table_constraint} 
         [, { column datatype [DEFAULT expr] [column_constraint] ... 
            | table_constraint} ]...) 
         [AS subquery]

В приведенном выше синтаксисе DEFAULT указывает значение по умолчанию, которое можно использовать во время инструкции INSERT, если столбец игнорируется. Он не может содержать ссылки на другие столбцы таблицы или псевдостолбцы (CURRVAL, NEXTVAL, LEVEL и ROWNUM), кроме SYSDATE и USER, или на константы даты, которые указаны не полностью.

Ограничения - это правила, необязательно определяемые на уровне столбца или таблицы (рассматриваются далее в этой главе). Эти правила проверяются во время любого действия с данными (вставка, обновление) в таблице и вызывают ошибку, чтобы прервать действие при его нарушении.

Например, приведенный ниже оператор CREATE TABLE создает таблицу EMP_TEST. Обратите внимание на характеристики столбца, тип данных и точность.

CREATE TABLE SCOTT.EMP_TEST
(EMPID NUMBER,
ENAME VARCHAR2(100),
DEPARTMENT_ID NUMBER,
SALARY NUMBER,
JOB_ID VARCHAR2(3),
HIREDATE DATE,
COMM NUMBER);

Пользователь может ссылаться на таблицы из схемы другого пользователя, добавив к имени пользователя или схеме префикс имени таблицы. Например, пользователь GUEST желает запросить имя сотрудника и зарплату из таблицы EMP_TEST, принадлежащей SCOTT. Он может выполнить следующий запрос -

SELECT  ENAME, SALARY,
FROM 	GUEST.EMP_TEST;

Столбец может содержать значение по умолчанию во время создания таблицы. Это помогает ограничить попадание значений NULL в столбец. Значение по умолчанию может быть получено из литерала, выражения или функции SQL, которая должна возвращать совместимый тип данных в столбец. Обратите внимание, что в приведенной ниже инструкции CREATE TABLE столбец LOCATION_ID имеет значение по умолчанию 100.

CREATE TABLE SCOTT.DEPARTMENT
(DEPARTMENT_ID NUMBER,
   DNAME VARCHAR2 (100),
   LOCATION_ID NUMBER DEFAULT 100);

CTAS - Создать таблицу с помощью подзапроса

Таблицу можно создать из существующей таблицы в базе данных с помощью параметра подзапроса, который копирует структуру таблицы, а также данные из таблицы. Данные также могут быть скопированы на основе условий. Определения типов данных столбцов, включая явно наложенные ограничения NOT NULL, копируются в новую таблицу.

Приведенный ниже сценарий CTAS создает новую таблицу EMP_BACKUP. Данные сотрудников отдела 20 копируются в новую таблицу.

CREATE TABLE EMP_BACKUP
AS
SELECT * FROM EMP_TEST
WHERE department_id=20;

Типы данных

Типы данных используются для определения основного поведения столбца в таблице. В более широком смысле, поведение столбца может принадлежать к числу, символу или семейству дат. Есть несколько других подтипов, которые принадлежат к этим семействам.

Тип данных числа

Тип данных NUMBER охватывает как целые числа, так и числовые значения с фиксированной и плавающей запятой. Ранние версии Oracle определяли разные типы данных для каждого из этих различных типов чисел, но теперь тип данных NUMBER служит всем этим целям. Выберите тип данных NUMBER, когда столбец должен хранить числовые данные, которые могут использоваться в математических вычислениях. Иногда тип данных NUMBER используется для хранения идентификационных номеров, где эти числа генерируются СУБД как последовательные числа.

ЧИСЛО (p, s), где p - точность до 38 цифр, а s - масштаб (количество цифр справа от десятичной точки). Шкала может находиться в диапазоне от -84 до 127.

ЧИСЛО (p) - это число с фиксированной точкой с нулевой шкалой и точностью p.

FLOAT [(p)], где p - двоичная точность, которая может находиться в диапазоне от 1 до 126. Если p не указан, значение по умолчанию - двоичное 126.

Тип данных даты

Для каждого типа данных DATE в базе данных хранятся век, год, месяц, день, час, минута, секунда. Каждая система баз данных имеет формат даты по умолчанию, который определяется параметром инициализации NLS_DATE_FORMAT. Этот параметр обычно установлен на ДД-МЕС-ГГ. Если вы не укажете время, время по умолчанию будет 12:00:00 am.

Тип символьных данных

Oracle поддерживает три предопределенных символьных типа данных, включая CHAR, VARCHAR, VARCHAR2 и LONG. VARCHAR и VARCHAR2 на самом деле являются синонимами, и Oracle рекомендует использовать VARCHAR2 вместо VARCHAR. Используйте тип данных CHAR, когда в столбце будут храниться символьные значения фиксированной длины. Например, номер социального страхования (SSN) в Соединенных Штатах присваивается каждому гражданину и всегда имеет размер 9 символов (хотя SSN строго состоит из цифр, цифры обрабатываются как символы) и будет определяться как CHAR (9). Используйте тип данных VARCHAR2 для хранения буквенно-цифровых данных переменной длины. Например, имя или адрес клиента могут значительно отличаться по количеству хранимых символов. Максимальный размер столбца VARCHAR2 составляет 4000 символов.

Тип данных LOB

Oracle предоставляет несколько разных типов данных LOB, включая CLOB (большой символьный объект) и BLOB (большой двоичный объект). Столбцы этих типов данных могут хранить неструктурированные данные, включая текст, изображения, видео и пространственные данные. Тип данных CLOB может хранить до восьми терабайт. символьных данных с использованием набора символов базы данных CHAR. Тип данных BLOB используется для хранения неструктурированных двоичных больших объектов, таких как те, которые связаны с данными изображения и видео, где данные представляют собой просто поток "битовых" значений. Тип данных BLOB может хранить до восемь терабайт двоичных данных. Тип данных NCLOB может хранить символьные большие объекты в многобайтовых национальных символах размером от 8 ТБ до 128 ТБ. Значение типа данных BFILE работает как указатель файла или указатель на файл в файловой системе сервера. Максимальный поддерживаемый размер файла составляет от 8 ТБ до 128 ТБ.

Ограничения

Ограничения - это набор правил, определенных в таблицах Oracle для обеспечения целостности данных. Эти правила применяются для каждого столбца или набора столбцов. Каждый раз, когда таблица участвует в действии данных, эти правила проверяются и вызывают исключение при нарушении. Доступные типы ограничений: NOT NULL, Primary Key, Unique, Check и External Key.

Приведенный ниже синтаксис можно использовать для наложения ограничений на уровне столбца.

Синтаксис:

column [data type] [CONSTRAINT constraint_name] constraint_type

Все ограничения, кроме NOT NULL, также могут быть определены на уровне таблицы. Составные ограничения можно указать только на уровне таблицы.

Ограничение NOT NULL

Ограничение NOT NULL означает, что строка данных должна иметь значение для столбца, заданного как NOT NULL. Если столбец указан как NOT NULL, СУБД Oracle не разрешит сохранять в таблице сотрудников строки, которые нарушают это ограничение. может быть определен только на уровне столбца, но не на уровне таблицы.

Синтаксис:

COLUMN [data type] [NOT NULL]

Уникальное ограничение

Иногда необходимо обеспечить уникальность значения столбца, не являющегося столбцом первичного ключа. Ограничение UNIQUE может использоваться для обеспечения выполнения этого правила, и Oracle отклонит все строки, которые нарушают ограничение уникальности. Ограничение уникальности гарантирует, что значения столбца различны , без дубликатов.

Синтаксис:

Column Level:

COLUMN [data type] [CONSTRAINT <name>] [UNIQUE]

Table Level: ОГРАНИЧЕНИЕ [имя ограничения] УНИКАЛЬНОЕ (имя столбца)

Примечание: Oracle внутренне создает уникальный индекс, чтобы предотвратить дублирование значений столбцов. Индексы будут обсуждаться позже в PL / SQL.

CREATE TABLE TEST
( ... ,
  NAME VARCHAR2(20) 
          CONSTRAINT TEST_NAME_UK UNIQUE,
  ... );

В случае составного уникального ключа он должен быть определен на уровне таблицы, как показано ниже.

CREATE TABLE TEST
( ... ,
  NAME VARCHAR2(20),
  STD VARCHAR2(20) ,
      CONSTRAINT TEST_NAME_UK UNIQUE (NAME, STD)
 );

Основной ключ

Каждая таблица обычно должна содержать столбец или набор столбцов, которые однозначно идентифицируют строки данных, которые хранятся в таблице. Этот столбец или набор столбцов называется первичным ключом. Большинство таблиц имеют единственный столбец в качестве первичного ключа. Ключевые столбцы ограничены NULL и повторяющимися значениями.

На заметку -

  • Таблица может иметь только один первичный ключ.

  • Составным первичным ключом можно объединить несколько столбцов.

  • Oracle внутренне создает уникальный индекс для предотвращения дублирования значений столбца. Индексы будут обсуждаться позже в PL / SQL.

Синтаксис:

Column level:

COLUMN [data type] [CONSTRAINT <constraint name> PRIMARY KEY]

Table level:

CONSTRAINT [constraint name] PRIMARY KEY [column (s)]

В следующем примере показано, как использовать ограничение PRIMARY KEY на уровне столбца.

CREATE TABLE TEST
( ID  NUMBER CONSTRAINT TEST_PK PRIMARY KEY,
  ...  );

В следующем примере показано, как определить составной первичный ключ с помощью ограничения PRIMARY KEY на уровне таблицы.

CREATE TABLE TEST
 ( ...,
   CONSTRAINT TEST_PK PRIMARY KEY (ID) 
 );

Внешний ключ

Когда две таблицы разделяют родительские дочерние отношения на основе определенного столбца, объединяющий столбец в дочерней таблице известен как внешний ключ. Это свойство соответствующего столбца в родительской таблице известно как ссылочная целостность. Значения столбца внешнего ключа в дочерней таблице могут либо иметь значение NULL, либо должны быть существующими значениями родительской таблицы. Обратите внимание, что только столбцы первичного ключа таблицы, на которую имеется ссылка, имеют право применять ссылочную целостность.

Если внешний ключ определен в столбце дочерней таблицы, Oracle не разрешает удаление родительской строки, если она содержит какие-либо дочерние строки. Однако, если во время определения внешнего ключа задана опция ON DELETE CASCADE, Oracle удаляет все дочерние строки, пока родительская строка удаляется. Аналогично, ON DELETE SET NULL указывает, что когда строка в родительской таблице удаляется, значения внешнего ключа устанавливаются на null.

Синтаксис:

Column Level:

COLUMN [data type] [CONSTRAINT] [constraint name] [REFERENCES] [table name (column name)]

Table level:

CONSTRAINT [constraint name] [FOREIGN KEY (foreign key column name) REFERENCES] [referenced table name (referenced column name)]

В следующем примере показано, как использовать ограничение FOREIGN KEY на уровне столбца.

CREATE TABLE TEST
(ccode varchar2(5) 
     CONSTRAINT TEST_FK REFERENCES PARENT_TEST(ccode),
   ...
);

Usage of ON DELETE CASCADE clause

CREATE TABLE TEST
(ccode varchar2(5) 
   CONSTRAINT TEST_FK REFERENCES PARENT_TEST (ccode)
   ON DELETE CASCADE,
   ...
);

Проверить ограничение

Иногда значения данных, хранящиеся в определенном столбце, должны попадать в некоторый допустимый диапазон значений. Ограничение CHECK требует, чтобы указанное условие проверки было истинным или неизвестным для каждой строки, хранящейся в таблице. Ограничение проверки позволяет наложить условное правило на столбец, который необходимо проверить перед вставкой данных в столбец. Условие не должно содержать подзапрос или псевдостолбец CURRVAL NEXTVAL, LEVEL, ROWNUM или SYSDATE.

Oracle позволяет одному столбцу иметь более одного ограничения CHECK. Фактически, нет практического ограничения на количество ограничений CHECK, которые могут быть определены для столбца.

Синтаксис:

Column level:

COLUMN [data type] CONSTRAINT [name] [CHECK (condition)]

Table level:

CONSTRAINT [name] CHECK (condition)

В следующем примере показано, как использовать ограничение CHECK на уровне столбца.

CREATE TABLE TEST
( ...,
   GRADE char (1) CONSTRAINT TEST_CHK
   CHECK (upper (GRADE) in ('A','B','C')),
   ...
);

В следующем примере показано, как использовать ограничение CHECK на уровне таблицы.

CREATE TABLE TEST
( ...,
   CONSTRAINT TEST_CHK
   CHECK (stdate < = enddate),
);

Оператор ALTER TABLE

Администратор базы данных может вносить изменения в структуру таблицы или определения столбцов после того, как таблица была создана в базе данных. Для выполнения таких действий используется команда DDL ALTER TABLE. Команда ALTER предоставляет несколько утилит, исключительных для объектов схемы. Используется оператор ALTER TABLE. для добавления, удаления, переименования и изменения столбца в таблице.

Приведенный ниже оператор ALTER TABLE переименовывает таблицу EMP в EMP_NEW.

ALTER TABLE EMP RENAME TO EMP_NEW;

Приведенный ниже оператор ALTER TABLE добавляет новый столбец TESTCOL в таблицу EMP_NEW.

ALTER TABLE EMP_NEW ADD (TESTCOL VARCHAR2 (100))

Приведенный ниже оператор ALTER TABLE переименовывает столбец TESTCOL в TESTNEW.

ALTER TABLE EMP_NEW RENAME COLUMN TESTCOL TO TESTNEW

Приведенный ниже оператор ALTER TABLE удаляет столбец TESTNEW из таблицы EMP_NEW

ALTER TABLE EMP_NEW DROP COLUMN TESTNEW;

Приведенный ниже оператор ALTER TABLE добавляет первичный ключ в столбец EMPLOYEE_ID.

ALTER TABLE EMP_NEW ADD PRIMARY KEY (EMPLOYEE_ID)

Приведенный ниже оператор ALTER TABLE удаляет первичный ключ.

ALTER TABLE EMP_NEW DROP PRIMARY KEY;

Приведенный ниже оператор ALTER TABLE переключает режим таблицы только для чтения.

ALTER TABLE EMP_NEW READ ONLY;

Таблицы только для чтения

Таблицы только для чтения стали усовершенствованием Oracle 11g. Они позволяют использовать таблицы только для чтения. В более ранних версиях оракула таблицы были сделаны только для чтения путем предоставления привилегии SELECT другим пользователям, но владелец все еще имел привилегию чтения и записи. Но теперь, если таблица установлена ​​как только для чтения, даже владелец не имеет доступа к манипулированию данными .

Синтаксис:

ALTER TALE [TABLE NAME] READ ONLY
ALTER TALE [TABLE NAME] READ WRITE

Иллюстрация

SQL>CREATE TABLE ORATEST (id NUMBER)

SQL>INSERT INTO ORATEST VALUES (1);

SQL>ALTER TABLE ORATEST READ ONLY;

SQL> INSERT INTO ORATEST VALUES (2);
INSERT INTO ORATEST VALUES (2)
            *
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"

SQL> UPDATE ORATEST SET id = 2;
UPDATE ORATEST SET id = 2
       *
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"

SQL> DELETE FROM ORATEST;
DELETE FROM ORATEST
            *
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"

SQL> TRUNCATE TABLE ORATEST;
TRUNCATE TABLE ORATEST
               *
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"

SQL> ALTER TABLE ORATEST ADD (description VARCHAR2 (50));
ALTER TABLE ORATEST ADD (description VARCHAR2 (50))
*
ERROR at line 1:
ORA-12081: update operation not allowed on table "TEST"."ORATEST"

SQL> ALTER TABLE ORATEST READ WRITE;

Table altered.

SQL> DELETE FROM ORATEST;

1 row deleted.

Инструкция DROP TABLE

Оператор DROP TABLE используется для удаления таблицы из базы данных. Отброшенная таблица и ее данные больше не доступны для выбора. Удаленную таблицу можно восстановить с помощью утилиты FLASHBACK, если она доступна в корзине. При удалении таблицы удаляется индекс и связанные с ним триггеры.

Синтаксис:

DROP TABLE [TABLE NAME] [PURGE]

Приведенный ниже оператор отбросит таблицу и поместит ее в корзину.

DROP TABLE emp_new;

Приведенный ниже оператор отбросит таблицу и также вымоет ее из корзины.

DROP TABLE emp_new PURGE;