Një bazë e të dhënave me objekte ose një bazë e të dhënave e orientuar në objekte është një sistem i menaxhimit të bazës së të dhënave në të cilin informacioni përfaqësohet në formën e objekteve siç përdoren në programimin e orientuar në objekte. Bazat e të dhënave të bazuara në objekte janë të ndryshme nga bazat e të dhënave relative të cilat janë të orientuara nga tabelat. Një lloj i tretë, bazat e të dhënave objekt-relative, është një hibrid i të dyja qasjeve. Bazat e të dhënave të objekteve janë konsideruar që nga fillimi i viteve 1980.[1]

Shembull i një modeli të orientuar ne objekte

Vështrim i përgjithshëm

Redakto

Sistemet e menaxhimit të bazës së të dhënave të orientuara në objekte (OODBMS) të quajtura gjithashtu ODBMS (Sistemi i Menaxhimit të Bazave të të Dhënave të Objekteve) kombinojnë aftësitë e bazës së të dhënave me aftësitë e gjuhës programuese të orientuara në objekte. OODBMS-të i lejojnë programuesit e orientuar në objekte të zhvillojnë produktin, t'i ruajnë ato si objekte dhe të përsërisin ose modifikojnë objektet ekzistuese për të krijuar objekte të reja brenda OODBMS. Për shkak se baza e të dhënave është e integruar me gjuhën e programimit, programuesi mund të ruajë qëndrueshmërinë brenda një mjedisi, në atë që si OODBMS ashtu edhe gjuha e programimit do të përdorin të njëjtin model përfaqësimi. Projektet relative DBMS, për dallim, mbajnë një ndarje më të qartë midis modelit të bazës së të dhënave dhe aplikacionit.

Teksa përdorimi i teknologjisë së bazuar në web rritet me zbatimin e Intraneteve dhe ekstraneteve, kompanitë kanë një interes të veçantë në OODBMS për të shfaqur të dhënat e tyre komplekse. Përdorimi i një DBMS që është krijuar veçanërisht për të ruajtur të dhënat si objekte u jep një përparësi atyre kompanive që janë të orientuara drejt prezantimit multimedial ose organizatave që përdorin dizajnin me ndihmën e kompjuterit (CAD)[2].

Disa baza të dhënash të orientuara në objekte janë krijuar për të punuar mirë me gjuhë programimi të orientuara ne objekte si Delphi, Ruby, Python, JavaScript, Perl, Java, C#, Visual Basic. NET, C++, Objective-C dhe Smalltalk; të tjerët si JADE kanë gjuhët e tyre të programimit. OODBMS përdorin saktësisht të njëjtin model si gjuhët e programimit të orientuara ne objekte.

Historia

Redakto

Sistemet e menaxhimit të bazës së të dhënave të objekteve u zhvilluan nga hulumtimi gjatë fillimit e deri në mes të viteve 1970, duke pasur një mbështetje të brendshme të menaxhimit të bazës së të dhënave për objektet e strukturuara në grafe. Termi "sistem i bazës së të dhënave të orientuar në objekte" u shfaq për herë të parë rreth vitit 1985.[3] Projekte të shquara kërkimore përfshinin Encore-Ob/Server (Universiteti Brown), EXODUS (Universiteti i Wisconsin-Madison), IRIS (Hewlett-Packard), ODE (Bell Labs), ORION (Mikroelektronikë dhe Teknologji Kompjuterike Korporata ose MCC), Vodak (GMD-IPSI), dhe Zeitgeist (Texas Instruments). Projekti ORION kishte më shumë punime të botuara se çdo përpjekje tjetër. Won Kim i MCC-së përpiloi më të mirët nga këto punime në një libër të botuar nga The MIT Press.[4]

Produktet e hershme komerciale përfshinin Gemstone (Servio Logic, emri i ndryshuar në GemStone Systems), Gbase (Graphael) dhe Vbase (Ontologjik). Produkte komerciale shtesë hynë në treg në fund të viteve 1980 deri në mesin e viteve 1990. Këto përfshinin ITASCA (Itasca Systems), Jasmine (Fujitsu, i tregtuar nga Computer Associates), Matisse (Matisse Software), Objectivity/DB (Objectivity, Inc.), ObjectStore (Progress Software, i blerë nga eXcelon i cili fillimisht ishte Object Design, Incorporated), ONTOS (Ontos, Inc., emri u ndryshua nga Ontologic), O2[5] (O2 Technology, u shkri me disa kompani, të blera nga Informix, e cila nga ana tjetër u ble nga IBM), POET (tani FastObjects nga Versant që bleu Poet Software), Versant Object Database (Versant Corporation), VOSS (Logic Arts) dhe JADE (Jade Software Corporation). Disa nga këto produkte mbeten në treg dhe u janë bashkuar produkte të reja me kod të hapur dhe produkte komerciale si InterSystems Cache.

Sistemet e menaxhimit të bazës së të dhënave të objekteve shtuan konceptin e qëndrueshmërisë në gjuhët e programimit të objekteve. Produktet e hershme komerciale u përfshinë me gjuhë të ndryshme: GemStone (Smalltalk), Gbase (LISP), Vbase (COP) dhe VOSS (Sistemi i ruajtjes së objekteve virtuale për Smalltalk). Për pjesën më të madhe të viteve 1990, C++ dominoi tregun e menaxhimit të bazës së të dhënave të objekteve komerciale. Shitësit shtuan Java në fund të viteve 1990 dhe së fundmi, C#.

Duke filluar nga viti 2004, bazat e të dhënave të objekteve kanë pasur një periudhë të dytë të rritjes kur u shfaqën bazat e të dhënave të objekteve me burim të hapur që ishin gjerësisht të arsyeshme dhe të lehta për t'u përdorur, sepse ato janë shkruar tërësisht në gjuhët OOP si Smalltalk, Java ose C#, siç është db4o e Versant-it (db4objects), DTS/S1 nga Obsidian Dynamics dhe Perst (McObject), i disponueshëm me burim të dyfishtë të hapur dhe komercial licencimi.

Afati kohor

Redakto
  • 1966
    • MUMPS
  • 1979
    • InterSystems M
  • 1980
    • TORNADO – an object database for CAD/CAM[6]
  • 1982
    • Gemstone started (as Servio Logic) to build a set theoretic model data base machine.
  • 1985 – Term Object Database first introduced
  • 1986
    • Servio Logic (Gemstone Systems) Ships Gemstone 1.0
  • 1988
    • Object Design, Incorporated founded, development of ObjectStore begun
    • Versant Corporation started (as Object Sciences Corp)
    • Objectivity, Inc. founded
  • Early 1990s
    • Servio Logic changes name to Gemstone Systems
    • Gemstone (Smalltalk)-(C++)-(Java)
    • GBase (LISP)
    • VBase (O2- ONTOS – INFORMIX)
    • Objectivity/DB
  • Mid 1990s
    • InterSystems Caché
    • Versant Object Database
    • ODABA
    • ZODB
    • Poet
    • JADE
    • Matisse
    • Illustra Informix
  • 2000s
    • lambda-DB: An ODMG-Based Object-Oriented DBMS by Leonidas Fegaras, Chandrasekhar Srinivasan, Arvind Rajendran, David Maier
    • db4o project started by Carl Rosenberger
    • ObjectDB
  • 2001 IBM acquires Informix
  • 2003 odbpp public release
  • 2004 db4o's commercial launch as db4objects, Inc.
  • 2008 db4o acquired by Versant Corporation
  • 2010 VMware acquires GemStone[7]
  • 2011 db4o's development stopped.
  • 2012 Wakanda first production versions with open source and commercial licenses
  • 2012 Actian acquires Versant Corporation
  • 2013 GemTalk Systems acquires Gemstone products from VMware[8]
  • 2014 db4o's commercial offering is officially discontinued by Actian (which had acquired Versant)[9]
  • 2014 Realm[10]
  • 2017 ObjectBox[11]

Adaptimi i bazave të të dhënave të objekteve

Redakto

Bazat e të dhënave në objekte, të bazuara në programimin e qëndrueshëm, kanë fituar një vend të veçantë në fusha aplikimi të tilla si inxhinieri dhe bazat e të dhënave hapësinore,, telekomunikacioni dhe fusha shkencore si fizika e energjisë së lartë[12] dhe biologjia molekulare.[13]

Një grup tjetër i bazave të të dhënave të objekteve fokusohet në përdorimin e integruar në pajisje, softuer të paketuar dhe sisteme në kohë reale.

Karakteristikat teknike

Redakto

Shumica e bazave të të dhënave të objekteve ofrojnë gjithashtu një lloj gjuhe të pyetjeve, duke lejuar që objektet të gjenden duke përdorur një qasje programimi deklarative. Është në fushën e gjuhëve të pyetjeve të objekteve, dhe integrimit të pyetjeve dhe ndërfaqeve të orientimit, që gjenden dallimet më të mëdha midis produkteve. Një përpjekje për standardizim u bë nga ODMG me gjuhën e pyetjes së objektit, OQL.

Qasja në të dhëna mund të jetë më e shpejtë sepse një objekt mund të merret direkt pa kërkim, duke i ndjekur treguesit.

Një fushë tjetër e dallimit midis produkteve është në mënyrën se si skema e një baze të të dhënave përcaktohet. Megjithatë, një karakteristikë e përgjithshme është se gjuha e programimit dhe skema e bazës të të dhënave përdorin përkufizime të të njëjtit lloj.

Aplikimet multimediale lehtësohen sepse metodat e klasës të lidhura me të dhënat janë përgjegjëse për interpretimin e saktë të tyre.

Shumë baza të të dhënave të objekteve, për shembull Gemstone ose VOSS, ofrojnë mbështetje për versionimin. Një objekt mund të shihet si grup i të gjitha versioneve të tij. Gjithashtu, versionet e objekteve mund të trajtohen si objekte më vete. Disa baza të të dhënave të objekteve ofrojnë gjithashtu mbështetje sistematike për shkaktarët dhe kufizimet të cilat janë baza e bazave të të dhënave aktive.

Efikasiteti i një baze të të dhënave të tillë është përmirësuar gjithashtu shumë në fushat që kërkojnë sasi masive të dhënash për një artikull. Për shembull, një institucion bankar mund të marrë informacionin e llogarisë së përdoruesit dhe t'i sigurojë atyre në mënyrë efikase informacione të gjera si transaksionet, hyrjet e informacionit të llogarisë e të tjera.

Standardet

Redakto

Grupi i Menaxhimit të të Dhënave të Objekteve ishte një konsorcium i shitësve të bazës së të dhënave të objekteve dhe hartës relative-objekt, anëtarë të komunitetit akademik dhe palëve të interesuara. Qëllimi i tij ishte të krijonte një sërë specifikimesh që do të lejonin aplikacione portative që ruajnë objektet në sistemet e menaxhimit të bazës së të dhënave. Ai publikoi disa versione të specifikimeve të tij. Lëshimi i fundit ishte ODMG 3.0. Deri në vitin 2001, shumica e bazës së të dhënave kryesore të objekteve dhe shitësve të hartës relative objekt pretenduan përputhshmëri me ODMG Java Language Binding. Pajtueshmëria me komponentët e tjerë të specifikimit ishte e përzier. Në vitin 2001, ODMG Java Language Binding iu dorëzua Procesit të Komunitetit Java si bazë për specifikimin e Objekteve të të Dhënave Java. Më pas, kompanitë anëtare të ODMG vendosën të përqendrojnë përpjekjet e tyre në specifikimin e Objekteve të të Dhënave Java. Si rezultat, ODMG u shpërbë në 2001.

Shumë ide të bazës së të dhënave të objekteve u absorbuan gjithashtu në SQL:1999 dhe janë zbatuar në shkallë të ndryshme në produktet e bazës së të dhënave objekt-relacionale.

Në vitin 2005 Cook, Rai dhe Rosenberger propozuan të hiqnin dorë nga të gjitha përpjekjet e standardizimit për të futur API shtesë të pyetjeve të orientuara nga objekti, por më tepër të përdornin vetë gjuhën e programimit OO, p.sh. Java dhe .NET, për të shprehur pyetje. Si rezultat, u shfaqën pyetje vendase. Në mënyrë të ngjashme, Microsoft njoftoi Language Integrated Query (LINQ) dhe DLINQ, një zbatim i LINQ, në shtator 2005, për të ofruar aftësi të afërta, të integruara në bazën e të dhënave të gjuhës me gjuhët e tij të programimit C# dhe VB.NET 9.

Në shkurt 2006, Grupi i Menaxhimit të Objekteve (OMG) njoftoi se atyre iu dha e drejta për të zhvilluar specifikime të reja bazuar në specifikimet ODMG 3.0 dhe formimin e Grupit të Punës të Teknologjisë së Bazave të të Dhënave të Objekteve (ODBT WG). ODBT GP planifikoi të krijonte një sërë normash që do të përfshinin përparimet në teknologjinë e bazës së të dhënave të objekteve (p.sh. replikimin), menaxhimin e të dhënave (p.sh. indeksimin hapësinor) dhe formatet e të dhënave (p.sh., XML) dhe të përfshinte veçori të reja në këto norma domenet mbështetëse ku janë duke u adoptuar bazat e të dhënave të objekteve (p.sh. sistemet në kohë reale). Puna e GP ODBT u ndërpre në mars 2009, si pasojë e trazirave ekonomike në fund të 2008, shitësit e ODB-së të përfshirë në këtë përpjekje vendosën t'i përqëndrojnë burimet e tyre dikund tjetër.

Në janar 2007, World Wide Web Consortium i dha statusin e sugjerimit përfundimtar gjuhës XQuery. XQuery përdor XML si modelin e tij të të dhënave. Disa nga idetë e zhvilluara për bazat e të dhënave të objekteve gjetën rrugën e tyre në XQuery, por XQuery nuk është në thelb i orientuar drejt objektit. Për shkak të famës të XML, motorët XQuery garojnë me bazat e të dhënave të objekteve si një mjet për ruajtjen e të dhënave që janë shumë komplekse ose të ndryshueshme për t'u mbajtur në mënyrë të përshtatshme në një bazë të dhënash relative. XQuery gjithashtu lejon që modulet të shkruhen për të ofruar veçori të kapsulimit që janë ofruar nga sistemet e orientuara në objekte.

XQuery v1 dhe XPath v2 dhe më vonë janë të fuqishëm dhe janë të disponueshëm si në softuerin me kod të hapur ashtu edhe në libre (FOSS),[14][15][16] si dhe në sistemet komerciale. Ato janë të lehta për t'u mësuar dhe përdorur, dhe shumë të fuqishme dhe të shpejta. Ato nuk janë relacionale dhe XQuery nuk bazohet në SQL (megjithëse një nga njerëzit që projektoi XQuery gjithashtu shpiku SQL). Por ato gjithashtu nuk janë të orientuara nga objekti, në kuptimin e programimit: XQuery nuk përdor kapsulimin me fshehje, dërgim të nënkuptuar dhe klasa dhe metoda. Bazat e të dhënave XQuery në përgjithësi përdorin XML dhe JSON si një format shkëmbimi, megjithëse përdoren formate të tjera.

Që nga fillimi i viteve 2000, JSON ka fituar miratimin dhe famën e komunitetit në aplikacionet ku zhvilluesit kontrollojnë formatin e të dhënave. JSONiq, një analog pyetësor i XQuery për JSON (duke ndarë shprehjet dhe operacionet thelbësore të XQuery), demonstroi ekuivalencën funksionale të formateve JSON dhe XML për informacionin e orientuar drejt të dhënave.

Në janar 2016, me publikimin e PostgreSQL 9.5[17] OODBMS FOSS ishte i pari që ofroi një tip të të dhënave të brendshme efikase JSON (JSONB) me një bashkësi të plotë funksionesh dhe operacionesh, për të gjitha manipulimet bazë relative dhe jo-relative.

Krahasimi me RDBMS

Redakto

Një bazë e të dhënave e objekteve ruan të dhëna komplekse dhe marrëdhënie midis të dhënave drejtpërdrejt, pa hartuar në rreshta dhe kolona relative, dhe kjo i bën ato të përshtatshme për aplikacione që kanë të bëjnë me të dhëna shumë komplekse.[18] Objektet kanë një marrëdhënie shumë-me-shumë dhe arrihen me anë të përdorimit të treguesve. Treguesit janë të lidhur me objekte për të vendosur marrëdhënie. Një përfitim tjetër i një OODBMS është se ai mund të programohet me dallime të vogla procedurale pa ndikuar në të gjithë sistemin.[19]

Shihni gjithashtu

Redakto
  • Krahasimi i sistemeve të menaxhimit të bazës së të dhënave të objekteve
  • Baza e të dhënave e orientuar nga komponentët
  • Baza e të dhënave EDA
  • Korniza e objekteve të ndërmarrjes
  • NoSQL
  • Grupi i menaxhimit të të dhënave të objekteve
  • Baza e të dhënave objekt-relacionale
  • Qëndrueshmëria (shkenca kompjuterike)
  • Modeli relacional
  • Sistemi i menaxhimit të bazës së të dhënave relacionale (RDbMS)

Referime

Redakto
  1. ^ "ODBMS (2013-08-31)" (në anglisht). Arkivuar nga origjinali më 6 mars 2014. Marrë më 16 dhjetor 2024.
  2. ^ O’Brien, J. A.,, & Marakas. Management Information Systems (9th ed) (në anglisht).{{cite book}}: Mirëmbajtja CS1: Emra të shumëfishtë: lista e autorëve (lidhja) Mirëmbajtja CS1: Pikësim shtesë (lidhja)
  3. ^ "An Object-Oriented DBMS for Design Support Applications", Proceedings of the IEEE COMPINT 85, pp. 299-307, September 1985; N. Derrett, W. Kent, and P. Lyngbaek, "Some Aspects of Operations in an Object-Oriented Database", Database Engineering, vol. 8, no. 4, IEEE Computer Society, December 1985; D. Maier, A. Otis, and A. Purdy, "Object-Oriented Database Development at Servio Logic", Database Engineering, vol. 18, no.4, December 1985 (në anglisht).
  4. ^ Won, Kim. Introduction to Object-Oriented Databases. The MIT Press, 1990 (në anglisht). The MIT Press, 1990.
  5. ^ Bancilhon, Francois; Delobel, Claude; and Kanellakis, Paris. Building an Object-Oriented Database System: The Story of O2. Morgan Kaufmann Publishers, 1992 (në anglisht).
  6. ^ Ulfsby; etj. (korrik 1981). "TORNADO: a DBMS for CAD/CAM systems". Computer-Aided Design (në anglisht). 13 (4): 193–197. doi:10.1016/0010-4485(81)90140-8.
  7. ^ "SpringSource to Acquire Gemstone Systems Data Management Technology" (në anglisht). WMware. 6 maj 2010. Arkivuar nga origjinali më gusht 8, 2014. Marrë më 5 gusht 2014.{{cite web}}: Mirëmbajtja CS1: Datë e përkthyer automatikisht (lidhja)
  8. ^ GemTalk Systems (2 maj 2013). "GemTalk Systems Acquires GemStone/S Products from VMware" (në anglisht). PRWeb. Arkivuar nga origjinali më gusht 10, 2014. Marrë më 5 gusht 2014.{{cite web}}: Mirëmbajtja CS1: Datë e përkthyer automatikisht (lidhja)
  9. ^ "restructuring our Versant Community Website" (në anglisht).
  10. ^ "Realm Releases Object Database for Node.js". InfoQ (në anglisht). Arkivuar nga origjinali më 2017-02-02.
  11. ^ DB-Engines. "Object Database Ranking on DB-Engines". DB-Engines (në anglisht). Marrë më 2021-05-21.
  12. ^ "Stanford Linear Accelerator (SLAC)" (në anglisht).
  13. ^ Herde, Patrick; Sibbald, Peter R. (1992). "Integration of molecular biology data collections using object oriented databases and programming". Addendum to the proceedings on Object-oriented programming systems, languages, and applications (Addendum) - OOPSLA '92 (në anglisht). fq. 177–178. doi:10.1145/157709.157747. ISBN 0897916107.
  14. ^ "BaseX XQuery Processor". basex.org (në anglisht). Arkivuar nga origjinali më 2023-12-16.
  15. ^ "XQuery in eXist-db". exist-db.org (në anglisht). Arkivuar nga origjinali më 2023-12-02.
  16. ^ "Saxon - Using XQuery". www.saxonica.com (në anglisht). Arkivuar nga origjinali më 2020-09-23.
  17. ^ "PostgreSQL: Documentation: 10: 9.15. JSON Functions and Operators". www.postgresql.org (në anglisht). Arkivuar nga origjinali më 2016-05-18.
  18. ^ Radding, Alan (1995). "So what the Hell is ODBMS?". Computerworld (në anglisht). 29 (45): 121–122, 129.
  19. ^ Donald, Burleson. . OODBMSs gaining MIS ground but RDBMSs still own the road. Software Magazine, 14(11), 63 (në anglisht). Software Magazine, 14(11), 63.

Lidhje të jashtme

Redakto

[[Kategoria:Sistemi i menaxhimit të Database]]