CREATE TABLE имя_таблицы
(список_определений_столбцов [,список ограничений_на_таблицу] )
Элементы списка всегда разделяются запятыми (в дальнейшем это будет считаться само собой разумеющимся и особо оговариваться не будет). Определение каждого столбца в списке имеет вид: имя_столбца тип_столбца [DEFAULT значение_по_умолчанию] [ограничения_на_столбец] Обязательными элементами описания столбца являются имя столбца и тип данных в столбце. Имя столбца должно быть уникальным в пределах таблицы. Стандартом SQL предусматривается набор основных типов данных. Внутреннее представление и ограничения на размер типов стандартом не устанавливаются, они по-разному реализуются в разных СУБД. Не все СУБД в полном объеме реализуют стандартные типы данных, кроме того, различные СУБД могут иметь собственные типы данных. Ниже мы приводим стандартные типы данных SQL 2003 и основные типы данных, поддерживаемые СУБД Oracle. При определении столбца для него может быть задано значение по умолчанию (DEFAULT). Если при занесении данных в строку таблицы не указывается значение для этого столбца, в столбец заносится значение по умолчанию. Если значение по умолчанию для какого-либо столбца при создании таблицы не задается, в случае отсутствия данных элемент этого столбца получает значение NULL. Типы данных Числовые типы Стандарт предусматривает следующие числовые типы. SMALLINT, INTEGER (INT) и BIGINT (последний появился только в SQL 2003) - целые двоичные числа со знаком, хотя стандарт не оговаривает размеры, в большинстве случаев это 2, 4 и 8 байт соответственно. NUMERIC(p,s) или NUMBER(p,s) или DECIMAL(p,s) - типы-синонимы для десятичных чисел с фиксированной точкой. Число p задает общее количество десятичных разрядов в числе, s - число разрядов после точки.
FLOAT(p), REAL, DOUBLE PRECISION - двоичные числа с плавающей точкой. Разрядность типов REAL и DOUBLE PRECISION зависит от реализации. В Oracle, в отличие от большинства других СУБД, внутреннее представление всех числовых данных одинаково – все числа хранятся в двоично-десятичном представлении (т.е. для каждой десятичной цифры числа хранится ее четырехбитное двоичное представление). Поэтому в Oracle имеется единственный числовой тип NUMBER[(p[,s])] Oracle, однако, принимает и все стандартные числовые типы и автоматически переводит их во внутреннее представление NUMBER. Например, стандартный тип INTEGER она автоматически приводит к типу NUMBER(38) – число без десятичной точки из 38 десятичных разрядов (один из них – знак числа) и отводит под него 38 байт, что в большинстве случаев избыточно. В целях рационального использования дискового пространства при работе с Oracle разумно пользоваться типом NUMBER. Например, для целых чисел (соответствующих типу INTEGER) разумным типом будет NUMBER(10). Вообще, для любой СУБД необходимо сначала внимательно изучить документацию по поддерживаемым типам и способам их внутреннего представления, а затем приступать к созданию таблиц. Знание внутреннего представления данных поможет не только сэкономить пространство на диске, но и повысить производительность СУБД за счет ускорения операций обмена между внешней и оперативной памятью. Константы числовых типов записываются так же, как и десятичные константы в большинстве языков программирования. Для действительных констант возможна нотация как с десятичной точкой, так и в E-форме. Символьные типы CHAR[ACTER] [(размер)] строка фиксированной длины (по умолчанию размер типа – 1 байт), максимальный размер в Oracle 2000 байт, но во многих СУБД размер этого типа ограничивается 256 байтами. VARCHAR(размер) (в Oracle дополнительно поддерживается тип VARCHAR2, идентичный VARCHAR, но гарантированно неизменный вне зависимости от возможного изменения типа VARCHAR в стандарте) — строка переменной длины, в Oracle его размер не более 4000 байт.
Данные типов CHAR и VARCHAR хранятся по разному. Под CHAR всегда отводится столько байт, сколько указано в размере, а под данные типа VARCHAR память на диске выделяется в соответствии с реальными размерами текста (все завершающие текст пробелы автоматически удаляются) плюс четыре байта для хранения этого размера. Пустая строка занимает 4 байта и содержит размер 0. В связи с этим для хранения таких данных, как наименования каких-либо объектов, предпочтительнее тип VARCHAR. Если предполагается, что столбец может содержать много NULL-значений (например, столбец «Примечания» или «Пояснения»), то тип VARCHAR также выигрывает перед типом CHAR. Стандартом также поддерживаются типы NCHAR (NATIONAL CHARACTER) и NVARCHAR, которые были введены для поддержки символов национальных алфавитов. Оба типа реализованы в Oracle и используются в том случае, если для кодирования символов используется Unicode. Константы символьного типа берутся в апострофы. Апостроф внутри символьной константы кодируется двумя апострофами.
Читайте также: ALTER TABLE Поставщик ADD CONSTRAINT CH_1 CHECK (Статус BETWEEN 10 AND 100) Воспользуйтесь поиском по сайту: ©2015 - 2024 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...
|