Мартин Грубер - Понимание SQL (991940), страница 27
Текст из файла (страница 27)
Значения вводятся с помощью DML команды INSERT(См. Главу 15). Команда CREATE TABLE в основном определяет имя таблицы, в видеописания набора имен столбцов указанных в определенном порядке. Она также определяет типы данных и размеры столбцов. Каждая таблица должна иметь по крайнеймере один столбец.Синтаксис команды CREATE TABLE:CREATE TABLE <table-name >( <column name > <data type>[(<size>)],<column name > <data type> [(<size>)] ... );Как сказано в Главе 2, типы данных значительно меняются от программы к программе.
Для совместимости со стандартом, они должны все, по крайней мере, поддерживать стандарт типа ANSI. Он описан в Приложении B.Так как пробелы используются для разделения частей команды SQL, они не могут быть частью имени таблицы (или любого другого объекта, такого как индекс). Подчеркивание (_) обычно используется для разделения слов в именах таблиц.Значение аргумента размера зависит от типа данных. Если вы его не указываете, ваша система сама будет назначать значение автоматически.
Для числовых значений, это — лучший выход, потому что в этом случае, все ваши поля такого типаполучат один и тот же размер, что освобождает вас от проблем их общей совместимости (см. Главу 14).Кроме того, использование аргумента размера с некоторыми числовым наборами, не совсем простой вопрос. Если вам нужно хранить большие числа, вам несомненно понадобятся гарантии, что поля достаточно велики чтобы вместить их.Один тип данных для которого вы, в основном, должны назначать размер —CHAR. Аргумент размера — это целое число которое определяет максимальноечисло символов которое может вместить поле. Фактически, число символов поля может быть от нуля (если поле — NULL) до этого числа. По умолчанию, аргумент разме-ра = 1, что означает, что поле может содержать только одну букву.
Это конечно несовсем то, что вы хотите.Таблицы принадлежат пользователю, который их создал, и имена всех таблиц,принадлежащих данному пользователю должны отличаться друга от друга, как и имена всех столбцов внутри данной таблицы. Отдельные таблицы могут использоватьодинаковые имена столбцов, даже если они принадлежат одному и тому же пользователю. Примером этому — столбец city в таблице Заказчиков и в таблице Продавцов.Пользователи не являющиеся владельцами таблиц могут ссылаться к этим таблицамс помощью имени владельца этих таблиц, сопровождаемого точкой; например, таблица Employees созданая Smith будет называться Smith.Employees когда она упоминается каким-то другим пользователем.
Мы понимаем что Smith — этоИдентификатор Разрешения (ID), сообщаемый пользователем (ваш разрешенный ID— это ваше имя в SQL). Этот вывод обсуждался в Главе 2, и будет продолжен в Главе22.Эта команда будет создавать таблицу Продавцов:CREATE TABLE Saleepeople( snum integer,sname char (10),city char (10),comm declmal );Порядок столбцов в таблице определяется порядком в котором они указаны.Имя столбца не должно разделяться при переносе строки (что сделано для удобочитаемости), но отделяется запятыми.ИНДЕКСЫИндекс — это упорядоченный (буквенный или числовой) список столбцов илигрупп столбцов в таблице.
Таблицы могут иметь большое колличество строк, а, так какстроки не находятся в каком-нибудь определенном порядке, на их поиск по указанному значению может потребовать время.Индексный адрес — это и забота, и в то же время обеспечение способа объединения всех значений в группы из одной или больше строк, которые отличаются однаот другой. В Главе 18, мы будем описывать более непосредственный способ, которыйзаставит ваши значения быть уникальными. Но этот метод не существует в раннихверсиях SQL. Так как уникальность часто необходима, индексы и использовались сэтой целью.Индексы — это средство SQL, которое родил сам рынок, а не ANSI.
Поэтому,сам по себе стандарт ANSI в настоящее время не поддерживает индексы, хотя ониочень полезны и широко применяемы.Когда вы создаете индекс в поле, ваша база данных запоминает соответствующий порядок всех значений этого поля в области памяти. Предположим что наша таблица Заказчиков имеет тысячи входов, а вы хотите найти заказчика с номером=2999.Так как строки не упорядочены, ваша программа будет просматривать всю таблицу,строку за строкой, проверяя каждый раз значение поля cnum на равенство значению2999.
Однако, если бы имелся индекс в поле cnum, то программа могла бы выйти наномер 2999 прямо по индексу и дать информацию о том как найти правильную строкутаблицы.В то время как индекс значительно улучшает эффективность запросов, использование индекса несколько замедляет операции модификации DML (такие как INSERTи DELETE), а сам индекс занимает объем памяти. Следовательно, каждый раз, когдавы создаете таблицу, Вы должны принять решение, индексировать ее или нет.Индексы могут состоять из многочисленых полей. Если больше чем одно полеуказыватся для одного индекса, второе упорядочивается внутри первого, третье внутри второго, и так далее. Если вы имели первое и последнее имя в двух различных полях таблицы, вы могли бы создать индекс который бы упорядочил предыдущее полевнутри последующего.
Это может быть выполнено независимо от способа упорядочивания столбцов в таблице.Синтаксис для создания индекса — обычно следующий (помните, что это неANSI стандарт):CREATE INDEX <index name> ON <table name>(<column name> [,<column name>]...);Таблица, конечно, должна уже быть создана и должна содержать имя столбца.Имя индекса не может быть использовано для чего-то другого в базе данных (любымпользователем).
Однажды созданый, индекс будет невидим пользователю. SQL самрешает когда он необходим чтобы ссылаться на него и делает это автоматически.Если, например, таблица Заказчиков будет наиболее часто упоминаемой в запросах продавцов к их собственной клиентуре, было бы правильно создать такой индекс в поле snum таблицы Заказчиков.CREATE INDEX Clientgroup ON Customers (snum);Теперь, тот продавец, который имеет отношение к этой таблице, сможет найтисобственную клиентуру очень быстро.УНИКАЛЬНОСТЬ ИНДЕКСАИндексу в предыдущем примере, к счастью, не предписывается уникальность,несмотря на наше замечание, что это является одним из назначений индекса. Данныйпродавец может иметь любое число заказчиков.
Однако, этого не случится, если мыиспользуем ключевое слово UNIQUE перед ключевым словом INDEX. Поле сnum, вкачестве первичного ключа, станет первым кандидатом для уникального индекса:CREATE UNIQUE INDEX Custid ON Customers (cnum);ПРИМЕЧАНИЕ: эта команда будет отклонена, если уже имеются идентичныезначения в поле cnum. Лучший способ иметь дело с индексами состоит в том, чтобысоздавать их сразу после того, как таблица создана и прежде, чем введены любыезначения.
Так же обратите внимание что, для уникального индекса более чем одногополя, это — комбинация значений, каждое из которых, может и не быть уникальным.Предыдущий пример — косвенный способ заставить поле cnum работать какпервичный ключ таблицы Заказчиков. Базы данных воздействуют на первичные и другие ключи более непосредственно. Мы будем обсуждать этот вывод далее в Главах 18и 19.УДАЛЕНИЕ ИНДЕКСОВГлавным признаком индекса является его имя — поэтому он может быть удален.Обычно пользователи не знают о существовании индекса. SQL автоматически определяет позволено ли пользователю использовать индекс, и если да, то разрешает использовать его. Однако, если вы хотите удалить индекс, вы должны знать его имя.Этот синтаксис используется для удаления индекса:DROP INDEX <Index name>;Удаление индекса не воздействует на содержание полей.ИЗМЕНЕНИЕ ТАБЛИЦЫ ПОСЛЕ ТОГО, КАК ОНА БЫЛАСОЗДАНАКоманда ALTER TABLE не часть стандарта ANSI; но это — широко доступная, идовольно содержательная форма, хотя ее возможности несколько ограничены.
Онаиспользуется, чтобы изменить определение существующей таблицы. Обычно, она добавляет столбцы к таблице. Иногда она может удалять столбцы или изменять их размеры, а также в некоторых программах добавлять или удалять ограничения(обсужденные в Главе 18). Типичный синтаксис чтобы добавить столбец к таблице:ALTER TABLE <table name> ADD <column name> <data type> <size>;Столбец будет добавлен со значением NULL для всех строк таблицы.