Создание БД с помощью SQL.
Последнее обновление: 09.07.2017
Создание базы данных
Для создания базы данных используется команда CREATE DATABASE .
Чтобы создать новую базу данных откроем SQL Server Management Studio. Нажмем на назначение сервера в окне Object Explorer и в появившемся меню выберем пункт New Query .
В центральное поле для ввода выражений sql введем следующий код:
CREATE DATABASE usersdb
Тем самым мы создаем базу данных, которая будет называться "usersdb":
Для выполнения команды нажмем на панели инструментов на кнопку Execute или на клавишу F5. И на сервере появится новая база данных.
После создания базы даных, мы можем установить ее в качестве текущей с помощью команды USE :
USE usersdb;
Прикрепление базы данных
Возможна ситуация, что у нас уже есть файл базы данных, который, к примеру, создан на другом компьютере. Файл базы данных представляет файл с расширением mdf, и этот файл в принципе мы можем переносить. Однако даже если мы скопируем его компьютер с установленным MS SQL Server, просто так скопированная база данных на сервере не появится. Для этого необходимо выполнить прикрепление базы данных к серверу. В этом случае применяется выражение:
CREATE DATABASE название_базы_данных ON PRIMARY(FILENAME="путь_к_файлу_mdf_на_локальном_компьютере") FOR ATTACH;
В качестве каталога для базы данных лучше использовать каталог, где хранятся остальные базы данных сервера. На Windows 10 по умолчанию это каталог C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA . Например, пусть в моем случае файл с данными называется userstoredb.mdf. И я хочу этот файл добавить на сервер как базу данных. Вначале его надо скопировать в выше указанный каталог. Затем для прикрепления базы к серверу надо использовать следующую команду:
CREATE DATABASE contactsdb ON PRIMARY(FILENAME="C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\userstoredb.mdf") FOR ATTACH;
После выполнения команды на сервере появится база данных contactsdb.
Удаление базы данных
Для удаления базы данных применяется команда DROP DATABASE , которая имеет следующий синтаксис:
DROP DATABASE database_name1 [, database_name2]...
После команды через запятую мы можем перечислить все удаляемые базы данных. Например, удаление базы данных contactsdb:
DROP DATABASE contactsdb
Стоит учитывать, что даже если удаляемая база данных была прикреплена, то все равно будут удалены все файлы базы данных.
Вплоть до этого места, мы запрашивали таблицы данных и выполняли команды по извлечению этих данных, считая, что эти таблицы уже были созданы кем - то до нас. Это действительно наиболее реальная ситуация, когда небольшое количество людей создают таблицы, которые затем используются другими людьми. Наша цель состоит в том, чтобы охватив информацию сначала более широко, перейти затем к более узким вопросам.
В этой главе, мы будем обсуждать создание, изменение, и удаление таблиц. Все это относится к самим таблицам, а не к данным которые в них содержатся. Будете или не будете Вы выполнять эти операции самостоятельно, но их концептуальное понимание увеличит ваше понимание языка SQL и природу таблиц которые вы используете. Эта глава вводит нас в область SQL называемую - DDL(Язык Определения Данных), где создаются объекты данных SQL.
Эта глава также покажет другой вид объекта данных SQL - Индекс. Индексы используются чтобы делать поиск более эффективным и, иногда, заставлять значения отличаться друга от друга. Они обычно работают незаметно для Вас, но если вы попробуете поместить значения в таблицу и они будут отклонены, из-за их неуникальности, это будет означать что друга строка имеет то же самое значение для этого по- л, и что это поле имеет уникальный индекс или ограничение которое предписывает ему уникальность. Обсуждение вышеупомянутого, продолжится в Главе 18 .
КОМАНДА СОЗДАНИЯ ТАБЛИЦЫ
Таблицы создаются командой CREATE TABLE. Эта команда создает пустую таблицу - таблицу без строк. Значения вводятся с помощью DML команды INSERT (См. Главу 15). Команда CREATE TABLE в основном определяет им таблицы, в виде описания набора имен столбцов указанных в определенном порядке. Она также определяет типы данных и размеры столбцов. Каждая таблица должна иметь по крайней мере один столбец.Синтаксис команды CREATE TABLE:
CREATE TABLE
Так как пробелы используются для разделения частей команды SQL, они не могут быть частью имени таблицы (или любого другого объекта, такого как индекс). Подчеркивание (_) - обычно используется для разделения слов в именах таблиц.
Значение аргумента размера зависит от типа данных. Если вы его не указываете, ваша система сама будет назначать значение автоматически. Для числовых значений, это - лучший выход, потому что в этом случае, все ваши пол такого типа получат один и тот же размер что освобождает вас от проблем их общей совместимости(см. Главу 14). Кроме того, использование аргумента размера с некоторыми числовым на- борами, не совсем простой вопрос. Если вам нужно хранить большие числа, вам несомненно понадобятся гарантии, что пол достаточно велики чтобы вместить их.
Один тип данных для которого вы, в основном, должны назначать размер - CHAR. Аргумент размера - это целое число которое определяет максимальное число символов которое может вместить поле. Фактически, число символов по- л может быть от нуля (если поле - NULL) до этого числа. По умолчанию, аргумент размера = 1, что означает что поле может содержать только одну букву. Это конечно не совсем то что вы хотите.
Таблицы принадлежат пользователю который их создал, и имена всех таблиц принадлежащих данному пользователю должны отличаться друга от друга, как и имена всех столбцов внутри данной таблицы. Отдельные таблицы могут использовать одинаковые имена столбцов, даже если они принадлежат одному и тому же пользователю. Примером этому - столбец city в таблице Заказчиков и в таблице Продавцов. Пользователи не являющиеся владельцами таблиц могут ссылаться к этим таблицам с помощью имени владельца этих таблиц сопровождаемого точкой; например, таблица Employees создана Smith будет называться Smith.Employees когда она упоминается каким-то другим пользователем (мы понимаем что Smith - это Идентификатор Разрешения (ID). (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 Предыдущий пример - косвенный способ заставить поле cnum работать как
первичный ключ таблицы Заказчиков. Базы данных воздействуют на первичные и другие ключи более непосредственно.
Мы будем обсуждать этот вывод далее в Главах 18 и .
ALTER TABLE - не действует, когда таблица должна быть переопределена,
но вы должны разрабатывать вашу базу данных по возможности так чтобы
не слишком ей в этом доверяться. Изменение структуры таблицы когда
она уже в использовании - опасно! Просмотрите внимательно таблицы, которые являясь вторичными таблицами с извлеченными данными из другой
таблицы (смотри Главу 20), не долго правильно работают, а программы
использующие вложенный SQL(Глава 25) выполняются неправильно или не
всегда правильно. Кроме того, изменение может стереть всех пользователей
имеющих разрешение обращаться к таблице.
По этим причинам, вы должны разрабатывать ваши таблицы так, чтобы использовать ALTER TABLE только в крайнем случае.
Если ваша система не поддерживает ALTER TABLE , или если вы хотите
избежать ее использования, вы можете просто создать новую таблицу, с необходимыми изменениями при создании, и использовать команду INSERT с
SELECT * запросом чтобы переписать в нее данные из старой таблицы.
Пользователям которым был предоставлен доступ к старой таблице
(см. Главу 22) должен быть предоставлен доступ к новой таблице.
Эта команда фактически не является частью стандарта ANSI, но она обще поддерживаемая и полезна. К счастью, она более проста, и следовательно более непротиворечивая, чем ALTER TABLE . ANSI просто не имеет способа
для определения разрушенных или неправильных таблиц.
Вы теперь знаете об индексах а также, как их создавать и удалять. SQL
не дает вам большого управления над ими, так как реализация которую
вы используете довольно удачно определяет, как быстро выполняются
различные команды. Индексы - это один из инструментов дающий Вам
возможность воздействовать непосредственно на эффективность ваших
команд в SQL. Мы рассмотрели индексы здесь чтобы отличать их от ограничений, с которыми их нельзя путать. Ограничения - это тема
Главы 18 и Главы 19 .
2. Напишите команду которая бы давала возможность пользователю
быстро извлекать порядки сгруппированные по датам из таблицы
Порядков.
3. Если таблица Порядков уже создана, как Вы можете заставить поле
onum быть уникальным (если допустить что все текущие значения
уникальны) ?
4. Создайте индекс который бы разрешал каждому продавцу быстро
отыскивать его порядки сгруппированные по датам.
5. Предположим, что каждый продавец имеет только одного заказчика
с данной оценкой, введите команду которая его извлечет.
Инсталлируйте программное обеспечение SQL Server Management Studio.
Это программное обеспечение можно бесплатно загрузить с сайта Microsoft. Оно позволяет вам подключаться и управлять вашим SQL сервером через графический интерфейс вместо того, чтобы использовать командную строку.
Запустите SQL Server Management Studio.
При первом запуске программы вам будет предложено выбрать, к какому сервер подключаться. Если у вас уже есть сервер и вы работаете, имеете необходимые разрешения для подключения к нему, то можете ввести адрес сервера и идентификационную информацию. Если вы хотите создать локальную базу данных, установите имя базы данных Database Name как. и тип аутентификации как "Windows Authentication".
Определите место для папки Databases.
После выполнения соединения с сервером (локальное или удаленное), откроется окно обозревателя объектов Object Explorer в левой стороне экрана. В верхней части дерева обозревателя объектов будет сервер, к которому вы подключены. Если дерево не расширено, нажмите на значок "+" рядом с ним. Определите место папки базы данных Databases. Создайте новую базу данных.
Щелкните правой кнопкой мыши по папке Databases и выберите пункт "New Database...". Появится окно, которое позволяет настроить базу данных перед ее созданием. Дайте имя базе данных, которое поможет вам идентифицировать ее. Большинство пользователей могут оставить значения остальных настроек по умолчанию.
Создайте таблицу.
База данных может только хранить данные, если вы создаете структуру для этих данных. Таблица содержит информацию, которую вы вводите в вашу базу данных, и вам нужно будет создать ее, прежде чем можете продолжить. Разверните новую базу данных в папке Databases, и щелкните правой кнопкой мыши на папке Tables и выберите пункт "New Table...".
Создайте Primary Key (первичный ключ).
Настоятельно рекомендуется, чтобы вы создавали первичный ключ в качестве первого столбца в вашей таблице. Он действует как идентификационный номер, или номер записи, что позволит вам легко выводить эти записи позже. Для его создания введите "ID" в столбце Name field, тип int в поле Data Type и снимите флажок "Allow Nulls". Нажмите на значок Key iна панели инструментов, чтобы установить этот столбец в качестве Primary Key (первичного ключа).
Разберитесь, как устроены таблицы.
Таблицы состоят из полей или столбцов. Каждый столбец представляет один из аспектов записи базы данных. Например, если вы создаете базу данных сотрудников, вы можете иметь столбец "FirstName", столбец "LastName", столбец "Address" и столбец "PhoneNumber". Создайте остальные столбцы.
Когда закончите заполнение полей для Primary Key, заметите, что новые поля появляются под ним. Это позволит вам войти в свой следующий столбец. Заполните поля, как считаете нужным, и убедитесь, что правильно выбрали тип данных для информации, которая будет введена в этом столбце:
Сохраните вашу таблицу.
Когда вы закончите создавать свои столбцы, то вам нужно сохранить таблицу перед вводом информации. Щелкните на значке Save на панели инструментов, а затем введите название таблицы. Рекомендуется присваивать имя таблице таким образом, чтобы оно помогло вам распознать содержимое, особенно для больших баз данных с несколькими таблицами. Добавьте данные в вашу таблицу.
После того, как вы сохранили таблицу, можете начать добавлять в нее данные. Откройте папку Tables в окне обозревателя объектов Object Explorer. Если вашей новой таблицы нет в списке, щелкните правой кнопкой мыши на папке Tables и выберите Refresh. Щелкните правой кнопкой мыши по таблице и выберите "Edit Top 200 Rows". Разновидность
языка, применяемая в конкретной СУБД,
называется диалектом
SQL
.
Например, диалект СУБДOracleназываетсяPL
/
SQL
;
вMSSQLServerиDB2 применяется диалектTransact
-
SQL
;
вInterbaseиFirebird–isql
. Каждый диалектSQLсовместим до определенной
степени со стандартомSQL,
но может иметь отличия и специфические
расширения языка, поэтому для выяснения
синтаксиса того или иногоSQL-оператора
следует в первую очередь смотретьHelp
конкретной СУБД. Ниже
приводится синтаксис этих операторов
по стандарту SQL92. Поскольку
их синтаксис в СУБД может отличаться
от стандарта, при выполнении лабораторной
работы рекомендуется обращаться к
справочной системе СУБД. Имена
объектов базы данных (таблиц, столбцов
и др.) могут состоять из буквенно-цифровых
символов и символа подчеркивания.
Специальные символы (@$# и т.п.) обычно
указывают на особый тип таблицы
(системная, временная и др.). Не рекомендуется
использовать в именах национальные
(русские) символы, пробелы и зарезервированные
слова, но если они всё же используются,
то такие имена следует писать в кавычках
".." или в квадратных скобках [..]. Далее
при описании конструкций операторов
SQLбудут использоваться
следующие обозначения: в квадратных
скобках записываются необязательные
части конструкции; альтернативные
конструкции разделяются вертикальной
чертой | ; фигурные скобки {} выделяют
логические блоки конструкции; многоточие…
указывает на то, что предшествующая
часть конструкции может многократно
повторяться. «Раскрываемые» конструкции
записываются в угловых скобках < >. Создание базы
данных
CREATE
DATABASE
Имя_базы_данных
Удаление
одной и более баз данных
DROP
DATABASE
Имя_базы_данных
[,Имя_базы_данных
…] USE
Имя_базы_данных
–-
в SQL
Server
и MySQL SET
DATABASE Имя
_
базы
_
данных
–
в
Firebird Создание
таблицы
CREATE
TABLE
Имя_таблицы
( <описание_столбца>
[,
<описание_столбца>
| <ограничение_целостности_таблицы>
…] <
описание_столбца
>
Имя_столбца
ТИП
{NO
ACTION|CASCADE|SET DEFAULT|SET NULL}] ТИП
столбца может быть либо стандартным
типом данных (см. таблицу 1), либо именем
домена (см. п.6.2). Некоторые
СУБД позволяют создавать вычислимые
столбцы
(computed
columns
).
Это виртуальные столбцы, значение
которых не хранится в физической памяти,
а вычисляется сервером СУБД при всяком
обращении к этому столбцу по формуле,
заданной при объявлении этого столбца.
В формулу могут входить значения других
столбцов этой строки, константы,
встроенные функции и глобальные
переменные. Описание
вычислимого столбца в SQL
Server
имеет вид: <описание_столбца>
Имя_столбца
AS
выражение
Описание
вычислимого столбца в Firebird
имеет вид: <описание_столбца>
Имя_столбца
COMPUTED
BY
<выражение>
СУБД MySQL
3.23 вычислимые столбцы не поддерживает. <
>
CONSTRAINT
Имя_ограничения_целостности
{UNIQUE|PRIMARY
KEY}(список_столбцов_образующих_ключ
) |FOREIGN
KEY (список
_
столбцов
_FK
) REFERENCES
Имя_таблицы
(список_столбцов_
PK
) {NO
ACTION|CASCADE|SET DEFAULT|SET NULL}] {NO
ACTION|CASCADE|SET DEFAULT|SET NULL}] |CHECK
(условие_проверки
) Некоторые
СУБД допускают объявление врéменных
таблиц (существующих только во время
сеанса). В SQL
Server
имена временных таблиц должны начинаться
с символа # (локальные временные таблицы,
видимые только создавшему их пользователю)
или ## (глобальные таблицы, видимые всем
пользователям); в MySQL
для создания временных таблиц используется
ключевое слово TEMPORARY,
например: CREATE
TEMPORARY
TABLE
…
(далее синтаксис см. CREATE
TABLE). Изменение
структуры таблицы
Используется
для изменения типа столбцов существующих
таблиц, добавления и удаления столбцов
и ограничений целостности. ALTER
TABLE
Имя_таблицы
Изменение типа столбца (в SQLServerиFirebird) ALTER
COLUMN
Имя_столбца
новый_ТИП Изменение типа, имени и ограничений
столбца (в MySQL) CHANGE
COLUMN
Имя_столбца
<описание_столбца>
Добавление обычного или вычислимого
столбца |ADD
<описание_столбца
>
Добавление ограничения целостности |
ADD <ограничение_целостности_таблицы
> Удаление столбца |DROP
COLUMN
Имя_столбца
Удаление ограничения целостности |DROP
CONSTRAINT
Имя_ограничения_целостности
Включение или отключение проверки
ограничений целостности ВMSSQLServer |{CHECK|NO
CHECK}
CONSTRAINT {Список_имен_ограничений_целостности
|ALL} Удаление
таблицы
DROP
TABLE
Имя_таблицы
Далее рассмотрим,
как при создании новых таблиц командой
CREATETABLEили
изменении структуры существующих таблиц
командойALTERTABLEобъявить декларативные ограничения
целостности (подробнее они описаны в
п.4.2) . 1. Обязательное
наличие данных
(NULL–значения) Объявляется
словом NULL(столбец может иметь пустые ячейки) илиNOT
NULL(столбец обязательный). По умолчанию
принимаетсяNULL. Пример
создания таблицы 7: CREATE
TABLE
Clients( ClientName
NVARCHAR
(60)
NOT
NULL
, DateOfBirth
DATE
NULL
, Phone
CHAR
(12));
-- по умолчанию тоже NULL 2. Значение
по умолчанию
(DEFAULT) Значение
по умолчанию можно задать для каждого
столбца таблицы. Если при модификации
ячейки ее новое значение не указано,
сервер вставляет значение по умолчанию.
Значение по умолчанию может быть NULL,
константой, вычислимым выражением или
системной функцией. Рассмотрим
пример создания таблицы Orders
(Заказы). Столбец OrderDate
принимает по умолчанию значение текущей
даты, а столбец Quantity
(количество) по умолчанию равен 0. CREATE
TABLE
Orders( OrderNum INT
NOT
NULL
, --
номер
заказа OrderDate DATETIME
NOT
NULL
-- дата
заказа DEFAULT
GetDate(), Функция
GetDate() возвращает
текущую
дату 8 Quantity SMALLINT
NOT
NULL
--
кол-во
товара, DEFAULT
0); 3. Объявление
первичных ключей
(PRIMARYKEY) Простой
первичный ключ объявляется словами
PRIMARYKEYпри
создании таблицы. Например, CREATE
TABLE
Staff(--
таблица "Работники"
TabNum INT
PRIMARY
KEY
, --
первичный ключ
WName NVARCHAR
(40)
NOT
NULL
,
-- ФИО ... --
описание прочих
столбцов
); Составной
первичный ключ объявляется иначе: --
способ 1
(объявление
PK
при создании таблицы)
CREATE
TABLE
Clients( PasSeria
NUMERIC
(4,0)NOT
NULL
,--
серия
паспорта
PasNumber NUMERIC
(6,0)NOT
NULL
,--
номер
паспорта
Name NVARCHAR
(40)NOT
NULL
, Phone CHAR
(12), --
объявление
составного первичного ключа
CONSTRAINT
Clients_PK PRIMARY
KEY
(PasSeria,PasNumber)); --
способ 2(PK
объявляется после создания таблицы)
--
сначала создаем таблицу без
PK
CREATE
TABLE
Clients( PasSeria
NUMERIC
(4,0)NOT
NULL
,--серия
паспорта
PasNumber NUMERIC
(6,0)NOT
NULL
,--номер
паспорта
ClientName NVARCHAR
(40)NOT
NULL
, Phone CHAR
(12)); --
модификация
таблицы
–
добавляем
РК
ALTER
TABLE
Clients ADD
CONSTRAINT
Clients_PK PRIMARY
KEY
(PasSeria,PasNumber); 4. Уникальность
столбцов
(UNIQUE)
Подобно
Primary
Key
указывает, что столбец или группа
столбцов не могут содержать повторяющихся
значений, но не являютсяPK
.
Все столбцы, объявленныеUNIQUE,
должны бытьNOTNULL.
Пример объявления простого уникального
столбца: CREATE
TABLE
Students( SCode INT
PRIMARY
KEY
,
-- суррогатный
РК FIO NVARCHAR
(40)
NOT
NULL
,
-- ФИО RecordBook
CHAR
(6)
NOT
NULL
UNIQUE
);
-- № зачетки Пример объявления
составного уникального поля: CREATE
TABLE
Staff(--
таблица
"
Работники
"
TabNum INT
PRIMARY KEY
, --
табельный
номер
WName NVARCHAR
(40)
NOT
NULL
, --
ФИО
PasSeria
NUMERIC
(4,0)
NOT
NULL
, --
серия
паспорта
PasNumber NUMERIC
(6,0)
NOT
NULL
, --
номер
паспорта
--
объявление
составного
уникального
поля
CONSTRAINT
Staff_UNQ UNIQUE
(PasSeria,PasNumber)); 5.
Ограничения
на
значения
столбца
(CHECK) Это
ограничение позволяет указать диапазон,
список или «маску» логически допустимых
значений столбца. Пример
создания таблицы Workers
(Работники)
: CREATE
TABLE
Workers( --
табельные номера 4-значные
TabNum INT
PRIMARY KEY
CHECK
(TabNum
BETWEEN
1000 AND
9999), Name VARCHAR
(60)
NOT
NULL
,
--
ФИО
сотрудника
--
пол
–
буква
"
м
"
или
"
ж
"
Gentry CHAR
(1)
NOT
NULL
CHECK
(Gentry IN
("м","ж")), Возраст
не
менее
14 лет Age SMALLINT
NOT
NULL
CHECK
(Age>=14), --№
свидет-ва пенсионного страхования (по
маске) PensionCert
CHAR
(14) CHECK
(PensionSert LIKE
"")); В
этом примере показаны разные типы
проверок. Диапазон допустимых значений
указывается конструкцией BETWEEN…AND; обычные условия (как
для столбцаAge
)
используют знаки сравнений =, <>, >,
>=, <, <=, связанные при необходимости
логическими операциямиAND,OR,NOT(например,Age
>=14ANDAge
<=70); для указания
списка допустимых значений используется
предикатINи его отрицаниеNOTIN;
конструкция LIKEмаска_допустимых_значений
EXCEPTсписок_исключений
используется для
задания маски допустимых значений
строковых столбцов. В маске применяются
два спецсимвола: «%» – произвольная
подстрока, и «_» – любой единичный
символ. Конструкция EXCEPTявляется необязательной. В
условии отбора CHECKмогут
сравниваться значения двух столбцов
одной таблицы и столбцы разных таблиц. Создание и удаление таблиц в ms sql server Все данные в БД sql server хранятся в таблицах. sql server поддерживает следующие типы данных: Тип данных Обозначение Размер, байт Таблицы можно создавать с помощью оператора create table языка transact-sql, а также с помощью enterprise manager. Рассмотрим сначала как это делается с помощью transact-sql. Содание таблиц с помощью create table create table table_name create table member
(member_no int not null,
lastname char(50) not null,
firstname char(50) not null,
photo image null) Этим оператором создается таблица member, состоящая из четырех колонок: member_no — имеет тип int, значения null не допускаются Попробуйте выполнить эту команду. Запустите query analyzer. Соединитесь с Вашим сервером. Из списка БД выберите sqlstep. Скопируйте в окно команд команду создания таблицы и выполните ее. (Если не забыли, надо нажать f5 или ctrl-e). Чтобы точно удостовериться, в том, что таблица была создана, наберите команду: sp_help member На заметку! sp_help — системная процедура, которая возвращает информацию об объектах БД (таблицах, хранимых процедурах и пр.). sp_help <имя таблицы> Удалить таблицу проще простого. Там же, в запросчике (так у нас называют query analyzer), наберите: drop table member Выделите эту строку и нажмите f5. Таблица будет удалена, о чем Вас и уведомят. В нашем случае эта процедура проста. На самом деле в большой БД просто так удалить таблицу не получится, поскольку она будет связана с другими таблицами, и для удаления потребуется эти связи оборвать. Как это сделать см. следующие шаги. Как создать таблицу с помощью sql server enterprise manager Введите названия колонок, их тип и длину также как в примере выше. Нажмите на иконку с дискетой для сохранения таблицы и можете закрыть окно. Раскройте вашу БД, щелкните на категории "tables" и в списке таблиц увидите только что введенную таблицу. Для ее удаления выделите ее в списке, нажмите правую кнопку мыши и в контекстном меню выберите "delete". Таблица будет удалена. Мы изучили как создаются и удалются таблицы. Следующий наш шаг — создание полноценной БД, на примере которой мы будем изучать: что такое реляционная целостность БД и как она обеспечивается в sql server Хорошо
Плохо
(
УНИКАЛЬНОСТЬ ИНДЕКСА
Индексу в предыдущем примере, к счастью, не предписывается уникальность,
несмотря на наше замечание, что это является одним из назначений индекса.
Данный продавец может иметь любое число заказчиков. Однако, этого не случится если мы используем ключевое слово UNIQUE перед ключевым словом
INDEX. Поле сnum, в качестве первичного ключа, станет первым кандидатом
для уникального индекса:
CREATE UNIQUE INDEX Custid ON Customers (cnum);
ПРИМЕЧАНИЕ: эта команда будет отклонена если уже имеются
идентичные значения в поле cnum. Лучший способ иметь дело с
индексами состоит в том, чтобы создавать их сразу после того,
как таблица создана и прежде, чем введены любые значения. Так
же обратите внимание что, для уникального индекса более чем
одного пол, это - комбинация значений, каждое из которых,
может и не быть уникальным.
УДАЛЕНИЕ ИНДЕКСОВ
Главным признаком индекса является его им - поэтому он может быть
удален. Обычно пользователи не знают о существовании индекса. SQL автоматически определяет позволено ли пользователю использовать индекс, и
если да, то разрешает использовать его. Однако, если вы хотите удалить
индекс, вы должны знать его им. Этот синтаксис используется для удаления индекса:
DROP INDEX ;
Удаление индекса не воздействует на содержание полей.
ИЗМЕНЕНИЕ ТАБЛИЦЫ ПОСЛЕ
ТОГО КАК ОНА БЫЛА СОЗДАНА
Команда ALTER TABLE не часть стандарта ANSI; но это - широко доступна, и довольно содержательна форма, хотя ее возможности несколько ограничены.
Она используется чтобы изменить определение существующей таблицы.
Обычно, она добавляет столбцы к таблице. Иногда она может удалять
столбцы или изменять их размеры, а также в некоторых программах добавлять или удалять ограничения (обсужденные в Главе 18).
Типичный синтаксис чтобы добавить столбец к таблице:
ALTER TABLE ADD
УДАЛЕНИЕ ТАБЛИЦЫ
Вы должны быть собственником(т.е. быть создателем) таблицы чтобы иметь
возможность удалить ее. Поэтому не волнуйтесь о случайном разрушении
ваших данных, SQL сначала потребует чтобы вы очистили таблицу прежде,
чем удалит ее из базы данных. Таблица с находящимися в ней строками, не
может быть удалена. Обратитесь к Главе 15 за подробностями относительно
того как удалять строки из таблицы. Синтаксис для удаления вашей таблицы,
если конечно она является пустой, следующая:
DROP TABLE < table name >;
При подаче этой команды, им таблицы больше не распознается и нет такой
команды которая могла быть дана этому объекту. Вы должны убедиться, что
эта таблица не ссылается внешним ключом к другой таблице(Внешние ключи обсуждаются в Главе 19), и что она не используется в определении Представления(Глава 20).
РЕЗЮМЕ
Теперь Вы уже бегло ориентируетесь в основах определений данных.
Вы можете создавать, изменять, и удалять таблицы. В то врем как
только первая из этих функций - часть официального стандарта SQL,
другие будут врем от времени меняться, особенно - ALTER TABLE.
DROP TABLE позволяет вам избавиться от таблиц которые бесполезны.
Она уничтожает только пустые таблицы, и следовательно не разрушает
данные.
РАБОТА С SQL
1. Напишите предложение CREATE TABLE которое бы вывело нашу
таблицу Заказчиков.
Для операций над базами данных и таблицами в стандарте sql предусмотрены операторы:
Объявление текущей базы данных
Таблицы состоят из колонок, объединяющих значения одного типа, и строк — записей в таблице. В одной БД может быть до 2 миллиардов таблиц, в таблице — 1024 колонки, в одной строке (записи) — 8060 байтов.
Бинарные данные binary
varbinary[(n)] 1-8000
Символы char[(n)]
varchar[(n)] 1-8000
(до 8000 символов)
Символы unicode nchar[(n)]
nvarchar[(n)] 1-8000
(до 4000 символов)
Дата и время datetime 8
smalldatetime 4
Точные числа decimal[(p[,s])]
numeric[(p[,s])] 5-17
Приблизительные числа float[(n)] real 4-8 4
Глобальный идентификатор uniqueidentifier 16
Целые числа int smallint, tinyint 4 2, 1
Денежки money, smallmoney 8, 4
Специальные bit, cursor,
sysname, timestamp 1, 0-8
Текст и изображение text, image 0-2 Гб
Текст unicode ntext 0-2 Гб
Для создания таблиц применяется оператор create table.
Вот как выглядит упрощенный синтаксис этого оператора:
(column_name data_type
[,…n])
Например:
lastname — имеет тип char(50) — 50 символов, значения null не допускаются
firstname — аналогично lastname
photo — имеет тип image (изображение), допускается значение null
Примечание
null — специальное обозначение того, что элемент данных не имеет значения. В описании типа колонки указывается, что элементы данных могут быть неинициализированы. При указании not null — "пустые" значения не допускаются. Если при вставке записи пропустить значение для такой колонки, вставка не произойдет, и sql server сгенерирует ошибку.
Выделите ее (как в обычном редакторе) и снова нажмите f5. В окно результатов будет выведена информация о таблице member.
Формат вызова таков:
Раскройте последовательно: sql server group, <Ваш sql server>, databases. Выберите БД (sqlstepbystep, я думаю:), нажмите правую кнопку мыши и выберите в контекстном меню пункт "new", а затем пункт "table…". Первым делом Вас спросят имя таблицы. Введите его и нажмите enter. На экране появится окно, в котором можно вводить:
имена колонок, тип, длину, размерность, точность (эти три колонки блокируются в зависимости от типа), флаг разрешения null, значение по умолчанию. Последние три колонки, пока не представляют интереса.
как модифицировать данные в таблицах (операторы insert, update, delete, select)
как использовать хранимые процедуры и триггеры