Садржај
1.0 Базе: Увод у базе података
Шта су базе података?
Табеларна организација података
Повезане табеле
Базе и табеле - квиз
1.1 Базе: SQLite
SQLite и SQLite Studio
Креирање базе у SQLite Studio
SQLite и SQLite Studio - квиз
Креирање базе у SQLite Studio - задаци за вежбу
1.2 Базе: Дизајнирање базе података
База компаније за продају дигиталних композиција - подаци о композицијама
База компаније за продају дигиталних композиција - подаци о продаји
Дизајнирање базе података - квиз
2.0 - SQL: Читање података из базе
SQL: Читање података из табела
Читање података - квиз
2.1 SQL: Пројекција и селекција
Пројекција
Селекција
Пројекција и селекција - квиз
Пројекција и селекција - задаци (дневник)
2.2 SQL: Логички и релацијски оператори
Логички оператори
Релацијски оператори
Оператори - квиз
Оператори - задаци (дневник)
2.3 SQL: Изрази и функције - Додатно
Изрази
Функције
Изрази и функције - квиз
Изрази и функције - задаци (дневник)
2.4 SQL: Сортирање, уклањање дупликата, ограничавање броја врста
Сортирање
Ограничавање броја врста у резултату
Уклањање дупликата
Сортирање, уклањање дупликата, ограничавање одговора - квиз
Сортирање и ограничавање - задаци (дневник)
2.5 SQL: Агрегатне функције и груписање
Агрегатне функције
Груписање и израчунавање статистика појединачних група
Селекција након груписања
Агрегатне функције и груписање - квиз
Агрегатне функције и груписање - задаци (дневник)
2.6 SQL: Спајање табела
Спајање табела
Имплицитно спајање
Спајање и груписање
Врсте спајања
Спајање табела - квиз
Спајање - задаци (дневник)
2.7 SQL: Угнежђени упити
Угнежђени упити
Угнежђени упити - квиз
Угнежђени упити - задаци (дневник)
2.8 SQL: Сложенији угњеждени упити - Додатно
Корелисани подупити
Провера постојања
2.9 SQL: Погледи
Погледи
Погледи - квиз
Погледи - задаци (дневник)
3.0 SQL: Промена садржаја базе
Измене података у бази
3.1 SQL: Уписивање података у табеле
Уписивање података
Уписивање података прочитаних из базе
Уписивање података - квиз
3.2 SQL: Ажурирање података у табелама
Ажурирање података
Ажурирање података - квиз
3.3 SQL: Брисање података из табела
Брисање података
Брисање података - квиз
4.0 Рачунарске мреже
Рачунарске мреже и интернет
Мрежни уређаји
Адресе
Мрежни слојеви и протоколи
Статичке веб-стране HTML/CSS
Дизајн веб-стране - CSS
Креирање веб-сајта
5.0 Серверско веб-програмирање
Веб-апликације - увод
Протокол HTTP
Протокол HTTP - квиз
5.1 Библиотека Flask - основни појмови
Библиотека Flask - увод
Библиотека Flask - прва веб-апликација, путање
Библиотека Flask - шаблони
Библиотека Flask - пратеће статичке датотеке и линкови унутар веб-апликације
Библиотека Flask - Метода GET
Библиотека Flask - Метода POST
Библиотека Flask - путање са параметрима
Библиотека Flask - колачићи
Библиотека Flask - сесије
Библиотека Flask - квиз
5.2 Библиотека Flask - повезивање са базом података
Повезивање са базом и постављање упита
Пренос параметара упита
Формулари и упити
Упис података у базу
Флешоване поруке
Валидација података унетих у формулар
AJAX
6.0 Библиотека Flask - пројектни задатак
О пројектном задатку
Регистрација корисника и логовање

Селекција (WHERE)

Као што смо могли да одаберемо само податке из неких колона, тако можемо да одаберемо и само податке из неких врста, тј. да извршимо филтрирање података на основу неког задатог услова. Тада је потребно да користимо следећи облик упита SELECT.

SELECT kolone
FROM tabele
WHERE uslov;

Када наведемо клаузулу WHERE, кажемо да је извршена селекција врста табеле, тј. да смо извршили филтрирање података. За овакав упит се каже и да извршава рестрикцију табеле.

Пројекцијом, дакле, избацујемо одређене колоне из резултата, а селекцијом (рестрикцијом) одређене врсте.

Селекцијом се из табеле издвајају само неке врсте

У наставку ћемо кроз низ примера илустровати различите облике услова које можемо да користимо.

Приказати све податке о ученицима првог разреда.

SELECT *
FROM ucenik
WHERE razred = 1;

Извршавањем упита добија се следећи резултат:

id

ime

prezime

pol

datum_rodjenja

razred

odeljenje

1

Петар

Петровић

м

2006-07-01

1

1

2

Милица

Јовановић

ж

2006-04-03

1

1

3

Лидија

Петровић

ж

2006-12-14

1

1

6

Јован

Миленковић

м

2006-04-07

1

2

7

Јована

Миленковић

ж

2006-04-07

1

2

Овај упит може да се протумачи као:

ОДАБЕРИ све колоне
ИЗ РЕДОВА табеле ученика
КОД КОЈИХ је разред једнак 1

Услов у овом упиту је razred = 1. Приметимо да у услову могу да се наводе називи колона табеле, као и константне вредности (у овом случају то је број 1), док се за једнакост користи знак =.

У систему SQLite Studio упити се пишу након што се кликне на креирану базу dnevnik у прозору Databases и потом изабере команда менија Tools Open SQL Editor. Када се напише упит, кликне се на дугме Execute query (F9) (плави троуглић). Уколико се у простору за писање упита налази више њих, потребно је обележити онај коју желимо да покренемо. Уколико имамо више база података, обавезно провери да ли је поред овог дугмета назив базе у којој желиш да вршиш упите.

На следећој слици може да се види упит покренут у систему SQLite Studio. Види се само првих неколико редова и информација о томе да има укупно 90 редова, односно толико има ученика који су први разред и налазе се у овој бази података. Када смо раније покренули упит којим се приказују сви редови у табели, могли само да видимо да их има 346, тако да је очигледно да је овде дошло до жељене селекције.

https://petljamediastorage.blob.core.windows.net/root/Media/Default/Kursevi/OnlineNastava/kurs-gim-cetvrti-prirodni-inf/1_razred.png

Приказати све податке о предметима у другом разреду.

SELECT *
FROM predmet
WHERE razred = 2;

Извршавањем упита добија се следећи резултат:

id

naziv

razred

fond

4

Математика

2

5

5

Психологија

2

2

7

Физика

2

3

24

Српски језик

2

3

25

Енглески језик

2

2

Приказати све податке о ученицима који се зову Петар.

SELECT *
FROM ucenik
WHERE ime = 'Петар';

Извршавањем упита добија се следећи резултат:

id

ime

prezime

pol

datum_rodjenja

razred

odeljenje

1

Петар

Петровић

м

2006-07-01

1

1

4

Петар

Миловановић

м

2005-12-08

2

1

50

Петар

Милић

м

2006-06-14

1

2

163

Петар

Платиша

м

2005-05-30

2

3

У овом упиту услов је ime = 'Петар'. Приметимо да је овај пут константна вредност 'Петар' наведена под једноструким наводницима, јер је у питању ниска карактера. Исти ефекат се може добити и ако се употребе двоструки наводници тј. ако се наведе "Петар".

Када је потребно да се уради претрага текстуалних података, добро је да се прво покрене основни упит и погледа садржај табеле да би се видело да ли су подаци у табели записани нашим ћириличним словима, нашим латиничним словима или словима енглеске абецеде, која називамо и „шишана“ латиница када се користи за наше речи. У нашој бази података су имена написана ћирилицом.

Извршавањем упита добија се следећи резултат:

id

ime

prezime

pol

datum_rodjenja

razred

odeljenje

1

Петар

Петровић

м

2006-07-01

1

1

4

Петар

Миловановић

м

2005-12-08

2

1

50

Петар

Милић

м

2006-06-14

1

2

163

Петар

Платиша

м

2005-05-30

2

3

Приказати све оцене добијене на писменим задацима.

SELECT *
FROM ocena
WHERE vrsta = 'писмени задатак';

Када је потребно да се уради претрага текстуалних података, добро је да се прво покрене основни упит и погледа садржај целе табеле да би се видело како су написани подаци. У овом случају, када је оцена добијена на писменом задатку, у бази је за врсту оцене записано: ’писмени задатак’.

Извршавањем упита добија се следећи резултат:

id

id_predmet

id_ucenik

ocena

datum

vrsta

11

1

1

3

2020-10-15

писмени задатак

12

1

2

3

2020-10-15

писмени задатак

13

1

3

2

2020-10-15

писмени задатак

15

1

14

3

2020-10-15

писмени задатак

16

1

15

1

2020-10-15

писмени задатак

Проверити да ли међу ученицима постоји неко ко се зове исто као што се и презива (приказати све такве ученике).

SELECT *
FROM ucenik
WHERE ime = prezime;

Извршавањем упита добија се следећи резултат:

id

ime

prezime

pol

datum_rodjenja

razred

odeljenje

201

Милић

Милић

м

2004-11-21

3

1

336

Милош

Милош

м

2003-08-09

4

3

Приказати све идентификаторе неоправданих изостанака.

У истом упиту се могу комбиновати пројекција и селекција, и ово је управо пример таквог упита.

SELECT id
FROM izostanak
WHERE status = 'неоправдан';

Извршавањем упита добија се следећи резултат:

id

2

5

9

10

11

Приказати све идентификаторе ученика и статусе изостанака направљених 14. маја 2021. године.

SELECT id_ucenik, status
FROM izostanak
WHERE datum='2021-05-14';

У овом упиту услов је datum='2021-05-14'. Приметимо да је овај пут константна вредност која представља датум 14. мај 2021. године наведена под једноструким наводницима, и то тако да прво пише година са четири цифре, па цртица, па месец са две цифре, па цртица, па дан са две цифре, тј. у формату gggg-mm-dd.

И у овом упиту су комбиновани пројекција и селекција.

У свим овим примерима вршили смо искључиво поређење коришћењем једнакости. У даљем раду ћеш научити да језик SQL подржава и друге релације.

Вежба

Пробај сада да самостално напишеш наредних неколико упита.

Приказати све податке о предметима који имају недељни фонд од 2 часа.



Издвојити имена и презимена ученика рођених 1. јула 2006. године.



Зашто се ова операција зове „селекција“, односно „рестрикција“?

И термини селекција врста табеле и рестрикција табеле долазе из формализма релационе алгебре.

Реч „селекција“ значи избор, а овде се односи на избор оних врста табеле, које задовољавају дати услов.

Реч „рестрикција“ значи ограничење, а у овом контексту говори да дату табелу ограничавамо само на оне врсте које задовољавају дати услов.

Претходна лекција
Следећа лекција
A- A+
Тема
Темa

Prijavi problem


Obeleži sve kategorije koje odgovaraju problemu

Još detalja - opišite nam problem


Uspešno ste prijavili problem!
Status problema i sve dodatne informacije možete pratiti klikom na link.
Nažalost nismo trenutno u mogućnosti da obradimo vaš zahtev.
Molimo vas da pokušate kasnije.