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

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

 


 

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

53887. Квадратне рівняння та його використання 87.5 KB
  Завдання: навчальні: відтворити знання про квадратне рівняння його види способи розвязування;вміння розвязувати квадратні рівняння. використовувати рівняння що зводяться до квадратних перетворювання раціональних виразів розвязування квадратичних виразів графічним способом; систематизувати та узагальнити навчальні досягнення учнів щодо розвязання квадратних рівнянь та їх використання в ході уроку та їх використання в ході уроку під час формування компетенцій учнів з алгебри;;розвивальні: розвивати увагу мислення пам'ять...
53889. Американська їжа. Традиційна українська кухня 332 KB
  Dear friends! I аm very glad to meet you here in our beautiful village and welcome you to the lesson About Americans Food. Today we shall speak English, watch video-cassettes. In other words we shall enjoy the English language today.
53890. Методика «Кулькова лялька» 90.5 KB
  Вік: рекомендуємо використовувати з 2х років разом з психологом з батьками до 11 років вік коли дитина ще вірить у казки чаклунство. Емоція яку проговорить дитина буде відображена на обличчі кулькової ляльки. Хід роботи: Чарівні маленькі предмети дитина кладе у коробок зпід кіндерсюрпризу. Дитина думає про те що їй допомагає та 3 рази дує в коробочок закриває його.
53891. Культура и традиции 62.5 KB
  И такой вариант возможен и у вас начнётся как переплетение с цветочками посредине. Допустим мы взяли черно злато белые цвета императорского штандарта. Что вам нужно Я взял три нитки можно цветов и поболее собрал их вместе. Можно подвести просто по одному цвету.
53892. Наземний, підземний, повітряний, водний – нас транспорт домчить будь-куди вже сьогодні 72.5 KB
  Тема: Наземний підземний повітряний водний - нас транспорт домчить будькуди вже сьогодні Автор: Ярмоленко Людмила Анатоліївна вчительлогопед ДНЗ №8 Золотий півник м. Вчительлогопед. Диференціація голосних та приголосних звуків Вчительлогопед. Вчительлогопед.
53893. Створення розвивально-ігрового середовища для розвитку творчого життя дошкільника 38 KB
  Продовжувати вчити виконувати роль кожного працівника кондитерського цеху знаходити методи спілкування між працівниками фабрики: кондитер завідувач кондитерським цехом директор секретар; будувати правильні міжрольові діалоги; закріпити засвоєні знання дітей із культури ділового спілкування; продовжувати вчити застосовувати свої знання на практиці в нестандартних умовах; закріпити вміння творчо працювати групами і допомагати один одному співпереживати. Розширювати уявлення дітей про роботу малих підприємств; закріпити вміння виконувати...
53894. Формування культури учнів засобами навчальних предметів 75 KB
  Як зазначено у Концепції загальної середньої освіти:Слайд №3 Освіта ХХІ століття – це освіта для людини її стрижень – розвиваюча культуротворча домінанта виховання відповідальної особистості яка здатна до самоосвіти та саморозвитку вміє критично мислити опрацьовувати різноманітну інформацію прагне змінити на краще своє життя і життя своєї країни.Слайд №4 ХХІ століття – це час переходу до високотехнологічного інформаційного суспільства у якому якість людського потенціалу рівень освіченості й культури всього населення...
53895. Позакласний захід «Фестиваль грецької культури» 2.09 MB
  Україна - толерантна, багатонаціональна держава. Більше 50 націй і національностей проживають в ній. За 20-літнє незалежне існування, великі і малі народи України, отримали можливість всебічного розвитку своєї культури, традицій, мови. Один з таких народів греки.