Adatbáziskezelés Horváth Ernő 1
Elérhetőségek Kiss Jenő Horváth Ernő Tanszéki honlap 2
Kabinet használat Felhasználó név: EIK Jelszó nincs L:\- írási jog, vizsgán használható D:\- írási jog C:\temp - ide érdemes dolgozni 3
Népszerű RDBMS-ek MySQL (Oracle Corp) Oracle (Oracle Corp) Cassandra (Apache) DB2 (IBM) Teradata (NCR) SQL Server (Microsoft) 4
SQL Server 2008 Letölthető: MSDNAA Express változat ingyenes (Server Management Studio külön települ, 4GB limit) 5
SQL Server Otthoni telepítés során meg kell adni a Server nevet, ez lehet tetszőleges, de ezzel kell belépni.\server formátumban
Adattípusok 1 bigint int smallint tinyint bit01, NULL is lehet minden megkezdett 8 bit típusú oszlop 1 byte decimal(p,s)-10^ ^38 –1 p-től függ numeric(p,s)-10^ ^38 –1 min. 5, max. 17 byte money , , smallmoney
Adattípusok 2 TípusMettőlMeddig Méret float(n)-1,79E ,79E n=1-24: 4 byte (7 jegy) real-3,40E + 383,40E + 38 (ua. float(24)) n=25-53: 8 byte (15) 8 TípusMettőlMeddig datetime (3.33 millisec pontosság)Jan Dec smalldatetime (1 perc pontosság)Jan Jun TípusLeírás charFix hosszú nem Unicode kar., maximum kar. varcharVáltozó hosszú nem Unicode kar., maximum kar. varchar(max)Változó hosszú nem Unicode kar., maximum 2 31 kar (csak SQL Server 2005). textVáltozó hosszú nem Unicode kar., maximum kar.
Adattípusok 3 9 TípusLeírás ncharFix hosszú nem Unicode kar., maximum kar. nvarcharVáltozó hosszú nem Unicode kar., maximum kar. nvarchar(max)Változó hosszú nem Unicode kar., maximum 2 30 kar (csak SQL Server 2005). ntextVáltozó hosszú nem Unicode kar., maximum kar. TípusLeírás binaryFix hosszú bináris adat., maximum byte. varbinaryVáltozó hosszú bináris adat., maximum byte. varbinary(max)Változó hosszú bináris adat., maximum 2 31 byte (csak SQL Server 2005). imageVáltozó hosszú bináris adat., maximum byte.
Legfontosabb adattípusok nchar (fix hosszúságú karakteres) nvarchar (változó hosszúságú karakteres) smalldatetime (év, nap, óra, perc) int (+- ~2milliárd) tinyint (0..255) 10
Alapfogalmak Egyed (entity): minden olyan objektum ami megkülönböztethető más objektumoktól. Pl. tanuló, gépjármű Tulajdonság (attribute): az egyedek leírására szolgál. Pl. név, neptun kód, alvázszám Kapcsolat: az egyedek közti viszony 1:1, 1:N, M:N 11
Relációs adatbázis Táblák Mezők Rekordok Kapcsolatok Kulcsok 12
Hogyan tároljunk nagy mennyiségű adatot? Miért nem jó így? 13
Miért nem jó? (folyt.) Redundáns (ismétlődő) adatok Adattípusok konzisztenciáját nem biztosítja Nem kereshető, nehezen átlátható Nem biztonságos Nincs verziókövetés Jobb lenne egy C/Java struktúrában tárolni? Sajnos nem sokkal. 14
Mi lehetne a jó megoldás? Relációs adatbázis Egyed- Kapcsolat diagramja 15
Hallgatók tábla neptun[nchar](6) NOT NULL, nev [nvarchar](50) NOT NULL, telepules[nvarchar](50) NOT NULL, utca[nvarchar](50) NOT NULL, irsz[nchar](10) NULL, tel[nvarchar](50) NULL, szdat[smalldatetime] NOT NULL, fiu[bit] NULL, kforma[nchar](10) NULL, kdij [money] NULL, egyeb [nvarchar](max) NULL, 16
Tantárgyak tábla tkod[nvarchar](50) NOT NULL, tnev[nvarchar](50) NOT NULL, kredit[tinyint] NOT NULL, tkov[nchar](10) NOT NULL, 17
Jegyek tábla neptun[nchar](6) NOT NULL, tkod[nvarchar](50) NOT NULL, jegy[tinyint] NOT NULL, vdatum[smalldatetime] NOT NULL, uv[tinyint] NULL, tanev[nchar](10) NULL, felev[nchar](10) NULL 18
Egyed- Kapcsolat modell Egyedhalmaz (táblák) Attribútum (sorok) Kapcsolat (közös kulcs) Összeköttetés 19
Terminológia idnevvaros 1.Kiss IstvánGyőr 2.Nagy ViktóriaBudapest 3.Kovács MihálySzekszárd 4.Szabó JánosÁcs Tábla Sorok (Rekordok) Oszlopok Mezők 20
Köszönöm a figyelmet! 21