Садржај
1 Релационе базе података
1.0 1 Релационе базе података
1.0 2 Релационе базе података - квиз
1.0 3 Веза један према више
1.0 4 Веза један према више - квиз
1.0 5 Веза више према више
1.0 6 Веза више према више - квиз
1.0 7 Алат за пројектовање
1.0 8 СУБП
1.0 9 Креирање базе на други начин
1.0 10 Још неке SQL команде
1.1 1 Упит SELECT
1.1 2 Упит SELECT - упит из једне табеле - задаци
1.1 3 Упит SELECT - упит из једне табеле - квиз
1.1 4 Упит SELECT - функције и подупити - задаци
1.1 5 Упит SELECT - функције и подупити - квиз
1.1 6 Упит SELECT - спајање - задаци
1.1 7 Упит SELECT - спајање - квиз
1.1 8 Упит SELECT - нерешени задаци
1.2 1 База података за библиотеку - креирање базе
1.2 2 БП Библиотека - Упит SELECT - упит из једне табеле - задаци
1.2 3 БП Библиотека - Упит SELECT - упит из једне табеле - нерешени задаци
1.2 4 БП Библиотека - Упит SELECT - спајање - задаци
1.2 5 БП Библиотека - Упит SELECT - спајање - нерешени задаци
1.2 6 БП Библиотека - Упит SELECT - функције и подупити - задаци
1.2 7 БП Библиотека - Упит SELECT - функције и подупити - нерешени задаци
1.3 1 База података за возачке дозволе - креирање базе
1.3 2 БП Возачке дозволе - Дијаграм и подаци - практичан рад
1.3 3 БП Возачке дозволе - Упит SELECT - задаци
1.3 4 БП Возачке дозволе - Упит SELECT - нерешени задаци
1.4 1 БП Филмови - Креирање базе - практични рад
1.4 2 БП Филмови - Дијаграм и подаци - практични рад
1.4 3 БП Филмови - Упит SELECT - задаци
1.4 4 БП Филмови - Упит SELECT - нерешени задаци
2 Писање програма унутар система за управљање базама података
2.0 1 Процедуре и команда INSERT
2.0 2 Процедуре и команде UPDATE и DELETE
2.0 3 Процедуре и команде INSERT, UPDATE, и DELETE - квиз
2.0 4 Процедуре и тестирање програма
2.0 5 Процедуре и упит SELECT
2.0 6 Процедуре и курсор за упит SELECT
2.1 1 Функције и упит SELECT
2.1 2 Процедуре и функције са упитом SELECT - квиз
2.1 3 Процедуре и функције са упитом SELECT из једне табеле - задаци
2.1 4 Процедуре и функције са упитом и групним функцијама - задаци
2.1 5 Процедуре и функције са упитом SELECT са спајањем табела - задаци
2.1 6 Процедуре и функције са упитом - нерешени задаци
2.1 7 Формат XML
2.2 1 База података за библиотеку - Процедуре, функције и поређење различитих решења
2.2 2 Процедуре, функције и поређење различитих решења
2.2 3 Процедуре и функције са упитом SELECT из једне табеле - вежбање
2.2 4 Процедуре и функције са упитом SELECT са спајањем табела - вежбање
2.2 5 Процедуре и функције са упитом и групним функцијама и подупитима - вежбање
2.2 6 Процедуре и функције са упитом SELECT - нерешени задаци
2.3 1 База података за возачке дозволе - процедуре и функције са упитом SELECT - вежбање
2.3 2 База података за возачке дозволе - процедуре и функције - нерешени задаци
2.4 1 База података за филмове - процедуре и функције са упитом SELECT - вежбање
2.4 2 База података за филмове - процедуре и функције - нерешени задаци
3 Писање програма у програмским језицима вишег нивоа
3.0 1 Писање програма у развојном окружењу Visual Studio
3.0 2 Писање програма у развојном окружењу Visual Studio - практичан рад
3.0 3 Писање програма у развојном окружењу Visual Studio - процедуре
3.0 4 Писање програма у развојном окружењу Visual Studio - квиз
3.1 1 Угнежђени упит SELECT унутар програма
3.1 2 Угнежђени упит SELECT унутар програма - задаци
3.1 3 Позив процедуре унутар програма
3.1 4 Позив креиране функције унутар програма
3.1 5 Програм са угнежђеним командама у развојном окружењу Visual Studio - квиз
3.1 6 Програм са угнежђеним упитом SELECT из једне табеле - вежбање
3.1 7 Програм са угњежђеним упитом и групним фунцкијама - вежбање
3.1 8 Програм са угнежђеним упитом SELECT са спајањем табела - вежбање
3.1 9 Програм са класом
3.1 10 Програм са угнежђеним упитом - нерешени задаци
3.1 11 Програм са угнежђеним командама INSERT, UPDATE, и DELETE
3.2 1 База података за библиотеку - програм са угнежђеним упитом SELECT из једне табеле - задаци
3.2 2 База података за библиотеку - програм са угнежђеним упитом SELECT - вежбање
3.2 3 База података за библиотеку - програм са угнежђеним упитом - нерешени задаци
3.3 1 База података за возачке дозволе - програм са угнежђеним упитом SELECT - вежбање
3.3 2 База података за возачке дозволе - програм са угнежђеним упитом - нерешени задаци
3.4 1 База података за филмове - програм са угнежђеним упитом SELECT - вежбање
3.4 2 База података за филмове - програм са угнежђеним упитом - нерешени задаци
4 Друга софтверска решења - СУБП Oracle
4.0 1 Oracle Apex и језик PL/SQL
4.0 2 Језик PL/SQL - задаци
4.0 3 Језик PL/SQL - квиз
4.0 4 Језик PL/SQL – нерешени задаци
4.0 5 Наредбе гранања
4.0 6 Наредбе гранања - нерешени задаци
4.0 7 Наредбе циклуса
4.0 8 Наредбе циклуса - нерешени задаци
4.1 1 База података за библиотеку - практичан рад
4.1 2 Наредба SELECT INTO
4.1 3 Наредба SELECT INTO - zadaci
4.1 4 Наредба SELECT INTO - квиз
4.1 5 Наредба SELECT INTO - вежбање
4.1 6 Наредба SELECT INTO - нерешени задаци
4.2 1 Курсори - Узимање података из више редова
4.2 2 Курсори - задаци
4.2 3 Различити начини да се реши проблем
4.2 4 Курсори - нерешени задаци
4.2 5 Курсор са параметром
4.2 6 Курсор са параметром - задаци
4.2 7 Курсор са параметром - нерешени задаци
4.2 8 Курсори - квиз
4.2 9 Курсори и гранање - задаци
4.2 10 Курсори - вежбање
4.2 11 Тренутне позајмице члана - пример
4.2 12 Спискови књига - пример
4.3 1 Процедуре и функције у СУБП-у Oracle Apex
4.3 2 Процедуре и функције - задаци
4.3 3 Процедуре и функције - нерешени задаци
4.3 4 Позајмице једне књиге - пример
4.3 5 Тренутне позајмице - пример
4.3 6 Процедуре и друге SQL команде
4.3 7 Тригери
4.3 8 Списак свих објеката у бази података
4.4 1 Креирање апликације помоћу алата App Builder
4.4 2 Додатне опције App Builder алата
4.4 3 Покретање апликације
4.4 4 Креирање нових страница у апликацији
4.4 5 Покретање раније креиране процедуре
4.4 6 Алат App Builder и XML
4.5 1 База података за салон аутомобила у СУБП-у Oracle Apex - 1. део
4.5 2 База података за салон аутомобила у СУБП-у Oracle Apex - 2. део
4.5 3 База података за салон аутомобила у СУБП-у Oracle Apex - 3. део
4.5 4 База података за продавницу - нерешени пројектни рад

Припрема за пројектни задатак

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

Сваки пут када треба да напишемо програм који ради са подацима, морамо процес решавања да започнемо пажљивим пројектовањем, а затим и креирањем базе података.

Најбољи начин да се разуме процес пројектовања и креирања база података јесте упознавање са што већим бројем примера. До сада је у материјалима приказано више примера база података различитих тежина. Неки примери су до краја решени и објашњени, а неки су остављени за самосталан рад. Кроз практичан рад на разноврсним примерима може да се прође све од пословног захтева до креирања конкретне базе података и да се стекну неопходне вештине за израду првог дела пројектног задатка.

У материјалима смо до сада видели дијаграме ентитета и веза, као и комплетно креиране следеће базе:

  • део базе података за библиотеку у којем се чувају подаци о свим књигама са 5 табела,

  • комплетну базу података за библиотеку са 10 табела,

  • базу података за евиденцију издатих возачких дозвола,

  • базу података за продајни салон аутомобила,

  • базу података за колекцију филмова (део базе неке онлајн платформе за пуштање филмова),

Као основа за задатке за самосталан рад приказани су креирани дијаграми ентитета и веза за још три базе података:

  • базу података за продавницу (део о производима, произвођачима, категоријама и ценама),

  • базу података за компанију за продају дигиталних композиција,

  • базу података за домаће задатке.

Након што креирамо базу података, следи писање програма, а то је процес који раздвајамо на два дела:

  • анализа података писањем упита SELECT или формирање неке друге команде језика SQL,

  • креирање програма који користи креирану базу у који је укључен претходно формиран упит SELECT или више команди језика SQL.

Узмимо пример са базом података за библиотеку. Библиотека размишља о набавци још књига неких аутора. Да би донели одлуку о новим набавкама, прво је потребно да провере стање са примерцима књига које већ имају од тих писца. Написати програм који приказује број примерака сваке књиге аутора чије се име и презиме унесе.

Како треба да се употреби команда упитног језика SQL унутар програмског кода писаног другим програмским језиком, први корак је да се конструише упит. Упит може да се напише и тестира за конкретног аутора.

SELECT COUNT(inventarski_broj), naziv
FROM primerci JOIN knjige ON (primerci.id_knjige=knjige.id_knjige)
JOIN autori_knjige ON (autori_knjige.id_knjige=knjige.id_knjige)
JOIN autori ON (autori_knjige.id_autora=autori.id_autora)
WHERE ime = 'Marko' AND prezime = 'Vidojkovic'
GROUP BY naziv

Када је упит тестиран, може да се укључи у програм, на пример процедуру која остаје сачувана у систему Microsoft SQL Server Management Studio.

CREATE PROCEDURE knjige_autora @ime_autora VARCHAR(15), @prezime_autora VARCHAR(15)
AS
    SELECT COUNT(inventarski_broj), naziv
    FROM primerci JOIN knjige ON (primerci.id_knjige=knjige.id_knjige)
    JOIN autori_knjige ON (autori_knjige.id_knjige=knjige.id_knjige)
    JOIN autori ON (autori_knjige.id_autora=autori.id_autora)
    WHERE ime = @ime_autora AND prezime = @prezime_autora
    GROUP BY naziv

Процедура може да се позове по потреби за различите ауторе.

EXEC knjige_autora @ime_autora = 'Marko', @prezime_autora = 'Vidojkovic'

EXEC knjige_autora @ime_autora = 'Dusa', @prezime_autora = 'Vukovic'

На исту тему могу да се разраде и сложенији програми. За библиотеку може, на пример, да буде значајан извештај којим ће за сваког аутора чије књиге има у понуди видети колико има примерака ког наслова. Овај програм може још да се надогради тако што ће списак аутора да се сортира по броју примерака које имамо у библиотеци, па да се разматра набавка још наслова оних аутора чијих књига има највише или најмање. Одлука може да се доноси и по броју позајмица, а не по броју постојећих примерака.

Као припрема за рад на пројектном задатку, може да се узме једна база података и да се прати кроз неколико поглавља. На пример, узети део базе података у којем се чувају подаци о свим књигама у библиотеци који има пет табела. Када се заврши анализа саме базе и прођу сви примери упита над њом у оквиру првог поглавља „Релационе базе података“, могу да се прескоче примери осталих база и да се пређе на примере са истом базом у другом поглављу „Писање програма унутар СУБП-а“, а затим одмах и на примере са истом базом у трећем поглављу „Писање програма у програмском језику вишег нивоа“.

(Created using Swinx, RunestoneComponents and PetljaDoc)
© 2022 Petlja
A- A+