Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

03 - Baze de Date PDF

Descărcați ca pdf sau txt
Descărcați ca pdf sau txt
Sunteți pe pagina 1din 30

Ce este o BAZA DE DATE?

In sens larg un sistem proiectat pentru a oferi un


mecanism organizat, capabil sa stocheze, sa actualizeze
si sa regaseasca informatia
Exemplu: o biblioteca
Noţiunea de bază de date este des vehiculată, prin ea
înţelegându-se o mare cantitate de date, de informaţii,
un mod de stocare electronică a datelor
Exemplu: cartea cu numerele de telefon, totalitatea foilor de
observaţie dintr-un spital, carnetele de note ale elevilor
O bază de date nu este altceva decât o colecţie de date
(informaţii) ce descriu mai multe subiecte (obiecte)
similare
Ce este un SISTEM DE GESTIONARE A
BAZELOR DE DATE?

Baza de date este o colecţie organizată de informaţii


Baza de date pentru a putea fi actualizata, modificata,
utilizata in obtinerea de rapoarte si statistici, se afla sub
controlul unui program. Întreg acest ansamblu poartă
numele de SGBD (Sistem de Gestionare a Bazelor de
Date), sau în engleză DBMS (Date Base Management
Sistem).
In practica prin baza de date se intelege de multe ori si
softul aferent, iar prin SGBD un sistem integrat in care
se pot construi si interoga baze de date
Administratorul bazei de date. - supraveghează atât asupra
integrităţii şi confidenţialităţii datelor cât şi asupra gestionării
utilizatorilor finali. Practic administratorul continuă activitatea
proiectantului SGBD-ului.
Proiectantului SGBD-ului este cel care stabileşte structura
bazei de date (adică ce insusiri sa descrie fiecare obiect,
subiect). Etapa este deosebit de importantă, de atenţia cu care
este parcursă depinzând succesul ulterior al aplicaţiei.
Trecerea structurii bazei de date într-un format electronic pe un
disc de calculator poartă numele de generare a bazei de date.
Odată generată structura, proiectantul transferă SGBD-ul
administratorului, care trece la supravegherea completării cu
informaţie. Această operaţie este efectuată de unul sau mai
mulţi operatori şi este, de cele mai multe ori este continuă,
derulându-se în paralel cu consultarea de bazei de date
(întocmirea de rapoarte şi statistici, plecând de la datele
deţinute).
Baze de date RELAŢIONALE
- înmagazinează datele în tabele care se pot lega logic
după valorile anumitor coloane
- relaţia dintre câmpuri realizează asocierea explicită
- este un model simetric, uniformitatea reprezentării
datelor determină uniformitate în mulţimea
operatorilor
- bazat pe teoria matematică a relaţiilor, proiectarea
bazelor de date poate fi tratată algoritmic
- utilizeaza un limbaj standardizat de interogare a
bazei de date numit SQL
Structura unei baze de date relationale
Informatiile sunt organizate in tabele, fiecare linie descriind
cate un subiect. Liniile nu trebuie sa fie identice! O linie
poarta numele de inregistrare.
Descrierea fiecarei insusiri a subiectului constituie un camp.
Informatia dintr-un camp nu trebuie sa poata fi descompusa!
Pentru fiecare câmp se alege un nume, un tip de date şi o
gamă de reprezentare.

Totalitatea campurilor ce descriu un subiect alcatuiesc o


inregistrare. Totalitatea inregistrarilor alcatuiesc baza de date
camp Camp cheie primara

camp 1 camp 2 camp 3 …. camp (n-1) camp n

Inregistrare

camp 1 camp 2 camp 3 …. camp (n-1) camp n


camp 1 camp 2 camp 3 …. camp (n-1) camp n
camp 1 camp 2 camp 3 …. camp (n-1) camp n
camp 1 camp 2 camp 3 …. camp (n-1) camp n
camp 1 camp 2 camp 3 …. camp (n-1) camp n
camp 1 camp 2 camp 3 …. camp (n-1) camp n
camp 1 camp 2 camp 3 …. camp (n-1) camp n
camp 1 camp 2 camp 3 …. camp (n-1) camp n

Baza de date
Tipuri uzuale de date (in Microsoft Access):
Text – folosit pentru informaţii ce nu depăşesc 255 de caractere
(litere,cifre,semne speciale)
Memo – folosit pentru informaţii ce depăşesc 255 de caractere (64KO;
ex:descrierea evoluţiei unei boli)
Number – folosit pentru informaţii numerice:
Byte – numere întregi în intervalul 0-255
Integer - numere întregi în intervalul -32768-+32767
Long integer - numere întregi în intervalul –2miliarde-+2miliarde
Single - numere zecimale în precizie simplă (7 cifre)
Double - numere întregi în intervalul (14 cifre)
Date/Time – folosit pentru informaţii de tip dată sau oră
Curency – folosit pentru informaţii numerice în bani
Autonumber – folosit pentru generarea automată de numere în ordine
crescătoare
Yes/No – folosit pentru informaţii binare de tip DA/NU
Proiectarea bazelor de date relationale

- identificarea entitatilor (tabelelor), relatiilor


dintre ele si propietatilor acestora
- elaborarea unor scheme conceptuale ce sa
ilustreze entitatile si legaturile dintre ele
- normalizarea relatiilor (obtinerea de relatii cat
mai simple, neincluse unele intre altele, eliminarea
redundantelor, dar cu conservarea datelor si a
dependentelor intre ele, in vederea eliminarilor
confuziilor si greselilor)
Relatii intre tabele
Campurile prin care se
realizeaza legaturile trebuie
sa fie de acelasi tip, in
prima tabela fiind cheie
primara, iar in a doua tot
cheie primara sau cheie
straina (adica primara in
prima tabela)

•1:1 (one to one) fiecarei linii in primul tabel ii corespunde cel mult o singura
linie in al doilea

•1:m (one to many) fiecarei linii in primul tabel ii pot corespunde mai multe in
al doilea si fiecarei linii al doilea ii corespunde exact una in primul

•m:m (many to many) unei linii in primul tabel ii pot corespunde mai multe in
al doilea si unei linii in al doilea tabel ii pot corespunde mai multe in primul
Fixarea legaturilor in
Access

unei linii in primul tabel ii pot corespunde


mai multe in al doilea si unei linii in al
doilea tabel ii pot corespunde mai multe in
primul
Normalizarea bazei de date

Informatiile nu trebuie repetate


Daca intr-un tabel dorim sa inseram coloane (campuri) existente deja
in alt tabel, vom insera doar cheia primara a acelui tabel.
Alternativa in care in fiecare tabel repetam datele generale despre
bolnav
Normalizarea bazei de date

Datele nu trebuie sa fie redundante


Tabelele trebuie construite in asa fel incat sa nu fie repetata
informatia pe randuri.
Alternativa de tabel in care sunt inscrise toate temperaturile, la
un loc cu datele generale despre pacient
Reguli de
integritate
pentru baze
de date
relationale

- cheia primara a unui tabel trebuie sa fie unica si minimala


- pentru fiecare rand din tabel cheia primara trebuie sa aiba atribuita
o valoare
- valoarea dintr-un tabel a unei chei straine trebuie sa se regaseasca
intre valorile din tabelul unde este cheie primara (principiu valabil
si la efectuarea de modificari in tabele)
Actualizarea informatiilor in Access in tabele cu legaturi

Fiecare pacient poate avea un numar diferit de temperaturi


memorate
Reguli definitorii ale bazelor de date relationale
(dr. Codd 1969-1970)
• informaţiile din baza de date sunt reprezentate exclusiv sub formă
tabelară
• toate datele individuale dintr-un tabel sunt oricând accesibile prin
specificarea numelui tabelului, a liniei şi a coloanei
• baza de date poate include ca valide valorile nule
• baza de date reprezintă descrierea informaţiilor înmagazinate într-
un format logic simplificat de genul tabelelor
• modelul relaţional are ca limbaj principal de interfaţare SQL, însă
poate suporta şi alte limbaje
• vederile sunt actualizabile, dacă vederea curentă este un tabel
• modelul relaţional tratează toate relaţiile ca un singur operand
pentru operaţiile de actualizare, inserare şi eliminare efectuate
asupra datelor
• aspectele logice ale bazei de date sunt complet separate de
aspectele fizice
• datele sunt conservate atunci când bazei de date i se aduc
modificări ilogice
• regulile de integritate sunt create în SQL, fiind stocate în catalogul
bazei de date şi nu în aplicaţiile individuale
• distribuţia datelor (copierea datelor într-o bază de date aflată la
distanţă) către programele de aplicaţie are loc continuu
• regulile şi restricţiile de integritate nu pot fi ocolite de nici un
limbaj de acces
• sistemul manevrează bazele de date folosind exclusiv
caracteristicile relaţionalele
Queries
Interogari

Aflarea tuturor
temperaturilor
tuturor
pacientilor
Queries - Interogari

Aflarea tuturor
temperaturilor
tuturor
pacientilor
Queries Interogari
Aflarea pacientilor febrili
Queries Interogari
Gasirea momentelor febrile
pentru pacientul Popescu
Arhitecturi de
implementare Modelul MAINFRAME-baza de
date este organizată şi stocată
integral pe un sistem performant
(denumit mainframe), de unde
Utilizator la
distanta poate fi accesată de mai multe
console utilizator prin intermediul
unor aplicaţii de exploatare
internet
rezidente tot pe mainframe
Baza date • modelul s-a dovedit performant şi
sigur în exploatare, reuşind să fie
integrat în arhitecturi moderne
• aplicaţiile au o structură rigidă,
extinderea presupunând rezolvarea
Utilizatori unor probleme privind organizarea
locali şi traficul de date
Arhitecturi de
implementare Modelul FILE-SERVER-
reţea centrată logic pe un
calculator puternic, numit file
server, de unde se
Utilizator la
distanta alimentează cu date şi
aplicaţii celelalte calculatoare
(PC) din reţea.
internet
• file server-ul partajează datele
Baza date pentru mai mulţi utilizatori,
oferindu-le sub forma unui
disc din reţea
• pentru mărirea vitezei de
acces la date este bine ca
Retea de reţeaua să fie de tipul stea şi
utilizatori nu liniară
locali
Arhitecturi de
implementare
BAZE DE DATE DISTRIBUITE
• autonomia locală, datele locale sunt administrate local, nici un post nu
depinde de altele pentru a lucra
• toate posturile sunt egale, nu există o staţie centrală
• funcţionarea este neîntreruptă, nu există opriri planificate
• transparenţa amplasării datelor, utilizatorii nu trebuie să ştie unde sunt
datele, pentru a le accesa
• trasparenţa fragmentării datelor
• transparenţa duplicării datelor
• prelucrarea de interogări distribuite şi actualizări distribuite
• independenţa de hardware şi de sistemul de operare
• independenţa de bazele de date, datele pot proveni din SGBD diferite
Modelul CLIENT-SERVER
• operare multiuser concurenţială
• descongestionarea traficului prin reţea prin trimiterea doar a
datelor ţintă
• controlul drepturilor utilizatorilor şi monitorizarea activităţii
• implementări unice de logică centralizată
• gestionarea tranzacţiilor client-server
• asigurarea de către server a integrităţii şi consistenţei datelor
• optimizarea organizării fizice a datelor
• recuperarea datelor în cazl căderii sistemului
• ridicarea performanţelor globale prin creşterea puterii
serverului bazei de date

S-ar putea să vă placă și