7598

Мова SQL. Загальна характеристика

Лекция

Информатика, кибернетика и программирование

Мова SQL Загальна характеристика. Як уже було сказано вище, обробка об’єктів БД виконуються мовою SQL, яка має певний набір команд. Команди SQL завжди починаються з дії (verb) - слова або групи слів, що описують задану операцію. Крім того,...

Украинкский

2013-01-26

116 KB

20 чел.

Мова SQL

Загальна характеристика. Як уже було сказано вище, обробка об’єктів БД виконуються мовою SQL, яка має певний набір команд. Команди SQL завжди починаються з дії (verb) – слова або групи слів, що описують задану операцію. Крім того, команда SQL може містити одну або декілька секцій, які уточнюють її сенс. Основні команди SQL перелічені в таблиці 3.1.

        Таблица 3.1 – Окремі команди PostgreSQL

Команда

Опис команди

CREATE 

Створення об’єкта бази даних

SELECT

Вибірка записів з таблиці

INSERT 

Вставка одного або декількох нових записів у таблицю

UPDATE 

Модифікація даних у записах

DELETE 

Видалення записів з таблиці

DROP 

Знищення об’єкта бази даних

ALTER 

Модифікація об’єкта бази даних

GRANT 

Надання користувачу прав доступу до об’єкта БД

REVOKE 

Позбавлення прав доступу до об’єкта БД

        PostgreSQL має цілий ряд розширень мови SQL, вони такі:

  •  збережені процедури; 
  •  тригери; 
  •  правила (rules); 
  •  агрегатні функції, задані користувачем;
  •  вбудовані мови програмування; 
  •  оператори, створені користувачем; 
  •  генератори числових послідовностей, задані користувачем; 
  •  нові типи даних, задані користувачем. 

        Наприкінці команди мовою SQL обов’язково ставиться крапка з комою.

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

        Кожна лексема може бути ключовим словом, ідентифікатором, захищеним ідентифікатором, константою або одним із спеціальних символів. До категорії ключових належать слова, які мають заздалегідь певний сенс у контексті SQL або PostgreSQL, це дії, секції, імена функцій і деякі необов’язкові складники команд SQL, наприклад, слово WORK у команді COMMIT. Ідентифікаторами позначаються імена змінних, таблиць, полів та інших об’єктів.

        Команди SQL можуть містити спеціальні символи. До них належать зарезервовані символи, вони впливають на зміст і розташування ключових слів, ідентифікаторів і літералів. До категорії спеціальних символів також належать і оператори, які використовуються в логічних та математичних виразах. Спеціальні символи можна розглядати як свого роду розділові знаки в командах SQL. Лексеми можуть знаходитися в одному або декількох рядках, оскільки модуль лексичного розбору PostgreSQL ігнорує зайві пробіли.

        Спеціальні символи не можна використовувати в ідентифікаторах, хоча, як згадувалося вище, це обмеження можна обійти за допомогою подвійних лапок. Вони подані в таблиці 3.2.

        Таблиця 3.2 – Спеціальні символи

Символ

Опис

* (зірочка)

Вибірка всіх полів таблиці командою SELECT, а також підрахунок всіх записів агрегатною функцією count()

( )  (круглі дужки)

Групування виразів, зміна пріоритету операторів, виклик функцій

 [ ]  (квадратні дужки)

Вибірка конкретного элемента масиву або оголошення типу массиву (наприклад, у команді CREATE TABLE)

; (крапка з комою)

Ознака завершення команди SQL. Всередині команди може вживатися в строковых константах і захищених ідентифікаторах

, (кома)

Розділювач елементів у списку

. (крапка)

Десяткова крапка у десяткових константах

: (двокрапка)

Позначення зрізу (slices) у масивах

$ (знак доллара)

Позначення позиційного параметра в визначенні функції

         Для забезпечення “читабельності” команда може містити однорядковий коментар, який починається знаком – – (два мінуси), та взятий у знаки /* та */ (у стилі мови С).

        Літерна константа (строка символів) являє собою довільну послідовність символів, вкладену у апострофи. Строкові константи часто використовуються при вставці нових даних у таблицю і при передачі символьної інформації іншим об’єктам бази даних. Якщо в самій послідовності символів зустрічається апостроф, то слід поставити два апострофи підряд. Модуль лексичного аналізу сприймає подвоєний апостроф у рядковій константі як один апостроф-літерал, наприклад, видача слів “Обєкт БД” виглядатиме так:

SELECT Об’’єкт БД’ AS example;

  example

---------------- 

 Обєкт БД

        PostgreSQL також дозволяє екранувати апострофи зворотною косою рискою, в стилі мови С, наприклад, так:

SELECT 'Об\’єкт БД' AS example;

        Бітові послідовності призначені для представлення двійкових величин у вигляді довільної послідовності нулів та одиниць. Вони звичайно потрібні лише під час роботи з двійковими функціями і таблицями, що містять двійкові дані. Як і строкові константи, бітові послідовності беруться в апострофи, але починаються вони з обов’язкового префікса В (верхнього або нижнього регістру), наприклад, так: B'00000000'.

        Цілочисловою константою вважається будь-яка лексема, яка складається з цифр (без десяткової крапки) і не взята в апострофи. Інтервал допустимих значень цілочислових констант у PostgreSQL за замовчуванням представляється чотирма байтами як цілочисловий тип і приймає значення з інтервалу від -2 147 483 648 до 2 147 483 647.

        Дійсні константи використовуються для задавання величин з дробовою частиною.

        Логічні (булеві) константи приймають лише два допустимі значення: true і false, не укладені в апострофи.

        Константою можна назвати й псевдозначення NULL, яке означає відсутність значень.

        Типи даних. Кожне поле таблиці характеризується певним типом даних, найбільш вживані типи перелічені в таблиці 3.3.  

        Таблиця 3.3 – Типи даних

Тип

Стандарт

Коментар

bool, boolean

SQL99

Логічний (true/false)

bit(n)

SQL92

Бітова послідовність довжиною n біт

character

SQL89

Рядок символів довжиною один символ

char(n), character (n)

SQL89

Рядок фіксованої довжини, рівно n символів

varchar(n)

SQL92

Рядок змінної довжини до n символів

text

PostgreSQL

Текст необмеженої довжини

float4, real 

SQL89

4- байтове дійсне число

float8, float 

SQL89

8-байтове дійсне число

int2, smallint 

SQL89

2-байтовое знакове ціле

int, int4, integer 

SQL92

4-байтове знакове ціле

int8, bigint

PostgreSQL

8-байтове знакове ціле, до 18 цифр 

date

SQL92

Календарна дата (день, місяць, рік)

time

SQL92

Час дня

interval

SQL92

Проміжок часу

timestamp

SQL92

Дата i час 

time with time zone

SQL92

Час дня з врахуванням зони

line

PostgreSQL

Лінія в одній площині (2D)

circle

PostgreSQL

Коло в одній плосколсти (2D)

lseg

PostgreSQL

Відрізок в одній площині (2D)

box 

PostgreSQL

Прямокутник в одній площині (2D)

point

PostgreSQL

Геометрична точка в одній площині (2D)

polygon

PostgreSQL

Закритий багатокутник в одній площині (2D)

inet

PostgreSQL

IP-адреса в формате IPv4

cidr

PostgreSQL

Ідентифікатор об’єкта (запису)

        Хоча PostgreSQL, як бачимо, має досить широкий спектр вбудованих типів даних,  але користувач може також утворювати власні типи командою CREATE TYPE.  

        Створення таблиці, точніше її макета, структури забезпечує команда CREATE TABLE. Її власником є користувач, який виконав цю команду.  

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

        Команда CREATE TABLE має такий загальний вигляд:

CREATE [ TEMPORARY | TEMP ] TABLE імя_таблиці (

{ ім’я_поля тип [ обмеження_поля [...] ] | обмеження таблиці } )

[ INHERITS ( базова_таблиця [ , ... ] ) ]

        Параметри команди:

  1.  TEMPORARY | TEMP. Ознака тимчасової таблиці. Таблиця, створена з ключовим словом TEMPORARY або TEMP, автоматично знищується наприкінці поточного сеансу Всі конструкції рівня таблиці (наприклад, індекси і обмеження) знищуються наприкінці сеансу разом з таблицею. Якщо ім’я тимчасової таблиці співпадає з ім’ям існуючої таблиці, то всі посилання на таблицю з цим ім’ям впродовж сеансу відноситимуться до тимчасової таблиці. Іноді це викликає проблеми, оскільки тимчасова таблиця побічно заміщає існуючу таблицю в контексті поточного сеансу до моменту її знищення.
  2.  таблиця. Ім’я створюваної таблиці, позначається ідентифікатором.
  3.  поле. Ім’я поля в новій таблиці, позначається ідентифікатором. Імена полів перераховуються в круглих дужках і розділяються комами.
  4.  тип. Відразу ж після імені користувача задається його тип – стандартний тип або масив одного із стандартних типів.
  5.  обмеження_поля.
  6.  базова_таблиця. Ім’я таблиці, від якої нова таблиця успадковує поля. Якщо імена успадкованих полів збігаються з іменами полів, раніше включених в структуру таблиці, PostgreSQL видає повідомлення про помилку і перериває виконання команди.

        У визначенні нової таблиці перераховуються всі імена і типи полів (крім полів, успадкованих від базової таблиці). Ім’я таблиці може мати довжину до 31 символа і автоматично перетвориться до нижнього регістра, якщо воно не взято в лапки. Імена таблиць не можуть збігатися з іменами існуючих типів даних і таблиць системного каталога, а також починатися з префікса pg_, зарезервованого для системних таблиць.

        Поле може мати стандартний тип даних (наприклад, integer, character) або містити масив (описується стандартним типом даних з квадратними дужками, наприклад, float[]). Максимальна кількість полів таблиці дорівнює приблизно 1600. З урахуванням проблем,

        Приклад, створити таблицю gazpr, яка має 4 поля: kod_g типу INTEGER, naz_g типу CHARACTER(50), kil_n типу INTEGER та diam типу INTEGER:

CREATE TABLE gazpr(kod_g INTEGER, naz_g CHARACTER(50), kil_n INTEGER, diam INTEGER);

        Вставка нових даних у таблицю виконуєтья командою INSERT, яка виглядає так:

INSERT INTO ім’я_таблиці [(перелік_імен_попів)] VALUES (перелік_значень)

        Тип кожного значення в секції VALUES повинен відповідати типу поля, якому воно присвоюється. Якщо необов’язковий список полів відсутній, то PostgreSQL припускає, що секція VALUES містить значення всіх полів таблиці в порядку їх визначення. Якщо кількість значень менше кількості полів, PostgreSQL намагається використовувати значення за замовчуванням (або NULL при його відсутності) для кожного пропущеного елемента.

     Таблиця Gazpr має містити контрольні дані. Ними, як правило, користуються на етапі налагодження програм. До контрольних даних ставляться певні вимоги. По-перше, вони не повинні бути громіздкими та багаточисленними, трудними для ручних обчислень, які виконуються паралельно з програмними і служать для перевірки правильності алгоритму. По-друге, ці дані повинні забезпечувати всі режими роботи програми та охоплювати всі діапазони зміни параметрів, які нею обробляються.

        У нижченаведеному прикладі створюється новий запис таблиці gazpr:

 

INSERT INTO gazpr(kod_g, naz_g, kil_n, diam) VALUES (1, 'Україна', 8, 1400);

        Якщо додаються значення всіх полів (як у цьому прикладі і це – найбільш поширений випадок), то перелік полів може бути опущений. Додамо, наприклад, запис у таблицю oblik, яка має 4 поля: kod_g, kod_p, kilk i data, за допомогою такої команди:

INSERT INTO oblik VALUES (3, 2, 3, '31.07.2012');

        Імена полів у списку можна переставити, але тоді повинен змінитися й відповідний їм порядок значень у секції VALUES.

        Нижче подані копії таблиць БД gazoprovid з контрольними даними.

        Таблиця gazpr:

kod_g,

integer

naz_g,

character(50)

kil_n,

integer

diam,

integer

1

Україна                                     

8

1400

2

Єлецьк-Орел                              

8

1800

3

Уренгой-Помари-Ужгород      

6

1800

4

Гадяч-Париж                           

7

1500

5

Гадяч-держкордон                   

2

 800

       

        Таблиця pidpr:

kod_p,

integer

naz_p,

character(50)

misto,

character(30)

1

Київтрансгаз

Київ

2

Гадячгазпром

Полтава

3

Львівгазпром

Львів

4

Прикарпаттрансгаз

Галич

        Таблиця oblik:

kod_g,

integer

kod_p,

integer

kilk,

real

data,

date

1

2

3

2010-06-12

2

2

5

2011-06-12

3

2

3

2012-07-31

4

2

5

2011-09-21

2

3

4

2012-06-13

9

4

2

2009-10-25

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

 


 

А также другие работы, которые могут Вас заинтересовать

83173. Финансовая ответственность и правонарушение 22.87 KB
  Самостоятельность финансовой ответственности подчеркивают специфические особенности финансового правонарушения. Понятие финансовое правонарушение носит собирательный характер оно объединяет бюджетные налоговые валютные и банковские правонарушения. Помимо конкретного перечня правонарушений Бюджетный кодекс содержит и само понятие...
83174. History of Basketball 23.7 KB
  Basketball is an extremely popular all around the world. The object is to put a ball through a hoop, or basket, and thus score more points than the opposing team. Teams comprise of ten players, with a maximum of five on court at any one time. Substitutions are unlimited during the course of the game.
83175. Нормы международного таможенного права в правовой системе Российской Федерации 32.46 KB
  Таможенное право комплексная отрасль права представляющая собой систему правовых норм различной правоотраслевой принадлежности которые устанавливаются санкционируются государством и предназначены для регулирования общественных отношений связанных с перемещением товаров и транспортных средств через таможенную границу взиманием таможенных...
83176. Развитие экономической теории в России 578.25 KB
  Успешное восстановление послевоенной экономики зависело не только от решения таких основных задач как собственно реконструкция восстановление разрушенного реконверсия перевод военного производства на выпуск гражданской продукции но и самого выбора варианта послевоенного хозяйственного развития страны.
83177. Сердечно – сосудистая система 606.63 KB
  В состав сердечно-сосудистой системы входит сердце орган который заставляет кровь двигаться нагнетая ее в кровеносные сосуды полые трубки различного калибра по которым она циркулирует. Кровь состоит из плазмы и приблизительно равного ей объема форменных элементов преимущественно красных клеток крови.
83178. Органы исполнительной власти Республики Беларусь 47.15 KB
  Исходя из данного определения - следующий уровень системы исполнительных органов – это республиканские органы государственного управления и иные государственные организации. Согласно Указу № 289 сюда входят министерства, государственные комитеты, являющиеся республиканскими органами государственного управления...
83179. Анализ природных ресурсов Кемеровской области 94.13 KB
  Кузнецкий бассейн расположен в Западно-Сибирском экономическом районе на территории Кемеровской области. Крайний юг области обширная территория средне-высоких гор Горной Шории. С 1943 центр Кемеровской области. Минерально-сырьевые ресурсы На территории области выявлены полезные ископаемые: уголь каменный бурый и горючие сланцы; чёрные металлы руда железная марганцевая; цветные и благородные металлы руда серебро ртуть свинец цинк медь барит бокситы нефелиновые руды...
83180. Несиметричні короткі замикання 71.15 KB
  Найбільш частим виглядом КЗ є несиметричні КЗ – однофазні, двофазні, двофазні на нейтраль. Вони є граничним випадком несиметричного навантаження. При несиметричних коротких замиканнях сталі струми короткого замикання досягають максимальних значень.
83181. Вентиляция, отопление и кондиционирование воздуха в производственных помещениях 68.08 KB
  Классификация систем кондиционирования. Вот некоторые задачи которые послужат для достижения этой цели: Выяснить значение кондиционирования воздуха. Классифицировать системы кондиционирования воздуха.