1 / 21

Definirea structurii unei baze de date

Definirea structurii unei baze de date. Notiunea de cheie primara. Rela ţ ionarea tabelelor. Proiectarea unei baze de date. Noţiunea de cheie primara - PRIMARY KEY. 1. Se selectează câmpul. Cheia primara identifică în mod unic o înregistrare a tabelei.

marek
Download Presentation

Definirea structurii unei baze de date

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Definireastructuriiuneibaze de date Notiunea de cheie primara Relaţionarea tabelelor Proiectarea unei baze de date.

  2. Noţiunea de cheie primara - PRIMARY KEY 1. Se selectează câmpul • Cheia primara identifică în mod unic o înregistrare a tabelei. • Poate fi : cheie simplă-formată dintr-o singură coloană cheie compusă (multiplă)- formată din mai multe coloane • Într-un tabel pot exista mai multe coloane (sau set de coloane) ce pot conţine valoriunice. Aceste coloane sunt chei candidat 2. Selectaţi fie simbolul iconic - cheie, din trusa standard, fie opţiunea Primary Key din meniul Edit Stabilirea cheii primare se poate face prin douã modalitãti, dupã cum urmeazã: 1. se selecteazã câmpul cod_cl; 2. a) se selecteazã butonul cheie din bara de instrumente Database; b) se activeazã opþiunea Primary Key din meniul Edit.

  3. Între două tabele dintr-o bază de date există o relaţie atunci când unul sau mai multe câmpuri cheie dintr-un tabel se potrivesc cu unul sau mai multe câmpuri cheie din celălalt tabel. Tabelul părinte (Departments) este tabelul care conţine cheia principală iar tabelele copil sunt tabelele corelate (Employees) Pentru a implementa relaţiile dintre tabele se folosesc cheile externe Relaţiiîntretabele Cheie externa Cheie principala

  4. Tipuri de relaţiiîn Access • 1. Relaţia One to One (unu la unu) - fiecărei înregistrări din tabelul părinte îi corespunde exact o singură înregistrare din tabelul copil. • 2. Relaţia One to Many (unu la mai mulţi) - fiecărei înregistrări din tabelul părinte îi corespunde mai mult de o înregistrare în tabelul copil. • 3. Relaţia Many to Many(mai mulţi la mai mulţi) – fiecărei înregistrări din tabelul părinte îi corespunde mai mult de o înregistrare în tabelul copil iar fiecărei înregistrări din tabelul copil îi poate corespunde mai mult de o înregistrare în tabelul părinte.

  5. Proiectareauneibaze de date. 1 ANALIZATI OBIECTIVUl URMARIT • Ce informaţii veţi stoca? • Cine le va folosi? • De ce fel de ieşiri aveţi nevoie? • Atunci când proiectaţi o bază de date trebuie să urmaţi o serie de paşi:

  6. Proiectarea unei baze de date 2. Determinaţi scopul bazei de date. Acest lucru vă ajută să stabiliţi ce fel de date vreţi să stocaţi în baza de date pe care o veţi crea (ex. gestiunea personalului, evidenţa stocurilor).

  7. Proiectarea unei baze de date 3. Determinaţi tabelele de care aveţi nevoie. Odată ce aveţi un scop clar stabilit,puteţi împărţi informaţiile în subiecte separate, ca se exemplu „Angajaţi”, „Clienţi”, sau „Comenzi”. Fiecare subiect va fi un tabel în baza de date. Numele tabelului trebuie să fie sugestiv pentru informaţiile pe care le va conţine.

  8. Proiectareauneibaze de date 4. Determinaţi câmpurile de care o să aveţi nevoie în tabele. • Hotărâţi ce fel de informaţii vor fi stocate în cadrul tabelelor. • Fiecare categorie de informaţii dintr-un tabel poartă denumirea de câmp (field) şi fiecare câmp va fi afişat pe o coloană în tabel. • De exemplu, un tabel cu denumirea Angajaţi poate să aibă următoarele câmpuri: Nume, Prenume, Data angajării, Salar_brut, Impozit.

  9. Proiectarea unei baze de date 4. Determinaţi relaţiile dintre tabele. Analizaţi cu atenţie tabelele şi stabiliţi legăturile care există între datele conţinute în tabele diferite. În cazul în care nu puteţi stabili relaţii între tabele, introduceţi tabele sau câmpuri de legătură.

  10. Proiectarea unei baze de date 5. Îmbunătăţirea proiectului. • Analizaţi proiectul pentru a găsi eventuale erori. • Creaţi tabelele şi adăugaţi câteva înregistrări de probă. Vedeţi dacă puteţi obţine din tabele rezultatele de care aveţi nevoie, faceţi modificări dacă este nevoie. • Pentru a parcurge etapele de mai sus puteţi folosi o tablă de scris sau hârtie şi creion pentru că veţi face multe modificări până veţi ajunge la o formă de proiectare acceptabilă. • Experimentaţi modelul proiectat, introduceţi date de test, creaţi formulare şi rapoarte de probă. Asiguraţi-vă că datele sunt stocate în mod corespunzător în baza de date şi că puteţi obţine toate informaţiile şi situaţiile finale dorite. Este mult mai dificil să modificaţi tabelele,formularele, rapoartele după ce au fost introduse date reale.

  11. APLICATIE Cititi cu atentie enuntul de mai jos! Este rezumatul unui interviu solicitat unui client care doreste sa ii proiectati o baza de date pentru a-si usura munca. “Sunt directorul unei firme care furnizeaza diverse cursuri de instruire in domeniul IT. Noi furnizam mai multe cursuri, fiecare are un cod, un nume si o durata in ore. Java Programming(ID=1), cu durata de 1 an si Programarea in C (ID=2) cu durata de doi ani sunt doua dintre cele mai populare cursuri. Un instructor poate preda mai multe cursuri. Maria Dinu si Mihai Ionescu sunt doi dintre cei mai buni profesori. Pastram pentru fiecare instructor numele si numarul de telefon. Un curs este sustinut doar de un singur instructor. Noi creem cursul iar apoi angajam instructorul. Studentii pot participa la mai multe cursuri in acelasi timp, si multi dintre ei o si fac. Dana Tudor de la firma CompNet a participat pana acum la toate cursurile noastre! Pentru fiecare student, noi retinem numele si numarul de telefon. Unii dintre studenti sau instructori, nu doresc insa sa ne dea numerele lor de telefon.”

  12. Pasul 1. • Care credeti ca estescopulbazei de date? Raspuns: Gestiuneapersonalului ( instructori),a clientiilor(studenti) si a serviciiloroferite de firma(cursuri)

  13. Pasul2 • Determinati tabelele de care aveti nevoie! • Tabelele sunt: Instructori Cursuri Studenti

  14. Pasul3 • Determinati campurile fiecarui tabel Raspuns: • Tabela Instructori va avea campurile Id_inst, Nume si Numar de telefon • Tabela Cursuri va avea campurile Id_curs, Nume, Durata • Tabela Studenti va avea campurile Id_st, Nume si Numar de telefon

  15. Pasul 4 • Stabilitiintrecetabeleexistarelatii • Raspuns: • IntretabelulCursurisiInstructori ( Un instructor poate tine maimultecursuriiar un curs poate fi tinut de un singur instructor) • Intra tabelaCursurisiStudenti (Un student poateparticipa la maimultecursuriiar la un curs pot participamai multi studenti)

  16. Pasul5 Creati tabelele si adaugati cateva inregistrari de proba

  17. Reducetirelatia de tip M-M dintretabeleleCursurisiStudenti la 2 relatii de tip 1-M • Raspuns: se insereaza o nouatabela (tabela de intersectie) numitaCursuriStudenti

  18. Rezultatul implementarii cu ajutorul Access:

  19. Pasul 6 • Se poate crea un raport cu studentii care frecventeaza cursurile tinute de doamna Maria Dinu? • Raspuns: • DA! Din tabela Cursuri se pot extrage cursurile tinute de d-na Dinu, iar apoi, din tabela Studenti, se vor extrage studentii care participa la aceste cursuri

  20. APLICATIE-tema: La biroul de internari a unuispital se retinurmatoarele date: • Date desprepacienti, date despremedicisi o evidenta a internarilorfacute. • Despre un pacienttrebuiesa se cunosca: cnp, nume, prenume, data nastere, adresa, ocupatie, stare civila(casatori/necasatorit). • Despre un medic trebuiesa se stie: numarullui de identificare in spital, nume, prenume, specializarea, nr telefon. • Cand se face internarea, suntobligatoriuretinute data internarii, diagnosticulsisalonulpacientului! • Stiind ca un medic poatetratamai multi pacientisi ca un pacient nu poate fi internatdecat o data sa se proiecteze o baza de date pentrubiroulinternari din care saextragetiurmatoarelerapoarte:

  21. - Pacientiiinternati in ziuax? • - Pacientiiunuianumit medic? • - Afisatitotipacientii cu diagnosticul “gripa” • - Afisatitotipacientii din salonul 2

More Related