Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Посібник Мова SQL кредитно-модульний.doc
Скачиваний:
35
Добавлен:
01.05.2015
Размер:
1.25 Mб
Скачать

Створення обмежень check

Обмеження CHECKстворюють одним з наступних способів:

  • під час створення таблиці (у складі визначення таблиці);

  • додають до існуючої таблиці.

Створені обмеження CHECKдозволено модифікувати й видаляти. Наприклад, можна модифікувати вираз, який використовується в обмеженніCHECK, визначеному для стовпця або таблиці.

Щоб модифікувати обмеження CHECKза допомогою Transact-SQL, спочатку варто видалити існуюче визначення обмеженняCHECK, а потім створити нове визначення.

У цьому прикладі створюється таблиця Tablelі визначається для стовбцясо1_2обмеженняCHECK, що обмежує введення значень з діапазоном 0 - 1000:

CREATE TABLE Table1

(

Col_l INT PRIMARY KEY,

Col_2 INT

CONSTRAINT limit_amount CHECK (Col_2 BETWEEN 0 AND 1000),

Col_3 VARCHAR(50)

)

Це обмеження також можна визначити на рівні таблиці:

CREATE TABLE Tablel

(

Col_l INT PRIMARY KEY,

Col_2 INT,

Col_3 VARCHAR(5O),

CONSTRAINT limit_amount CHECK (Col_2 BETWEEN 0 AND 1000)

)

Щоб додати обмеження СНЕСКдо існуючої таблиці, можна скористатися операторомALTERTABLE:

ALTER TABLE Tablel

ADD CONSTRAINT limit_amount CHECK (Col_2 BETWEEN 0 AND 1000)

При додаванні до існуючої таблиці обмеження CHECKзастосовується тільки до нових даних або до всіх даних таблиці, включаючи існуючі. За замовчуванням обмеженняCHECKзастосовується як до існуючих, так і до всіх нових даним. Можливість застосувати обмеження тільки до нових даних корисна, якщо існуючі дані вже відповідають новому обмеженнюCHECKабо якщо бізнес-правило вимагає, щоб обмеження застосовувалося, тільки починаючи із цього моменту.

Однак потрібно бути обережним при додаванні обмеження без перевірки існуючих даних, оскільки ця дія відбувається в обхід контролю SQL Server, що забезпечує цілісність дані таблиці.

Модифікація таблиць у базі даних sql Server

Після створення таблиці багато параметрів, певні під час її створення, дозволяється змінювати. Наприклад, додавати, модифікувати й видаляти стовпці, у тому числі змінювати ім'я, довжину, тип даних, точність (точність дробової частини), можливість уведення порожніх значень - останнє з деякими обмеженнями. Більш докладно про це розказано в SQL Server Books Online, а зараз ми просто перелічимо всі можливі операції:

  • додавання й видалення обмеження PRIMARY KEY і FOREIGN KEY;

  • додавання й видалення обмеження UNIQUE і CHECK, а також визначення обмежень (і об'єктів) DEFAULT;

  • додавання й видалення стовпців з ідентифікатором за допомогою властивостей IDENTITY або ROWGUIDCOL. Дозволяється додавати й видаляти властивість ROWGUIDCOL в існуючих стовпців, але при цьому в будь-який момент часу можливий тільки один стовпець із властивістю ROWGUIDCOL;

  • таблиці й обрані стовпці таблиці можна зареєструвати для повнотекстового індексування.

Видалення таблиці з бази даних sql Server

Іноді, наприклад, якщо потрібно реалізувати нову структуру або звільнити місце в базі даних, необхідно видалити таблицю. При цьому структурне визначення таблиці, дані, повнотекстові індекси, обмеження й індекси повністю віддаляються з бази даних, а місце, колись зайняте таблицею і її індексами, стає доступним для інших таблиць. Можна явно видалити тимчасову таблицю, якщо ви не хочете чекати на неї автоматичного видалення.

Якщо необхідно видалити таблиці, зв'язані за допомогою обмеження FOREIGN KEY, UNIQUE або PRIMARY KEY, те спочатку варто видалити таблиці з обмеженням FOREIGN KEY. Якщо потрібно видалити таблицю, на яку є посилання в обмеженні FOREIGN KEY, але при цьому повністю видаляти таблицю із зовнішнім ключем не можна, варто видалити обмеження FOREIGN KEY.

Видаляють таблицю з бази даних SQL Server за допомогою оператора DROP TABLE або SQL Server Management Studio (яка видаляє таблицю з вузла Tables). Наведемо простий приклад видалення таблиці Table1з бази даних за допомогою оператораDROPTABLE:

DROP TABLE Table1

На завершення наведемо декілька прикладів створення таблиць у базі даних BookShopDB.