fbpx
Wikipedia

Object–relational mapping

Object–relational mapping (ORM, O/RM, and O/R mapping tool) in computer science is a programming technique for converting data between a relational database and the heap of an object-oriented programming language. This creates, in effect, a virtual object database that can be used from within the programming language.

In object-oriented programming, data-management tasks act on objects that combine scalar values into objects. For example, consider an address book entry that represents a single person along with zero or more phone numbers and zero or more addresses. This could be modeled in an object-oriented implementation by a "Person object" with an attribute/field to hold each data item that the entry comprises: the person's name, a list of phone numbers, and a list of addresses. The list of phone numbers would itself contain "PhoneNumber objects" and so on. Each such address-book entry is treated as a single object by the programming language (it can be referenced by a single variable containing a pointer to the object, for instance). Various methods can be associated with the object, such as methods to return the preferred phone number, the home address, and so on.

By contrast, relational databases, such as SQL, group scalars into tuples, which are then enumerated in tables. Tuples and objects have some general similarity, in that they are both ways to collect values into named fields such that the whole collection can be manipulated as a single compound entity. They have many differences, though, in particular: lifecycle management (row insertion and deletion, versus garbage collection or reference counting), references to other entities (object references, versus foreign key references), and inheritance (non-existent in relational databases). As well, objects are managed on-heap and are under full control of a single process, while database tuples are shared and must incorporate locking, merging, and retry. Object–relational mapping provides automated support for mapping tuples to objects and back, while accounting for all of these differences.[1]

The heart of the problem involves translating the logical representation of the objects into an atomized form that is capable of being stored in the database while preserving the properties of the objects and their relationships so that they can be reloaded as objects when needed. If this storage and retrieval functionality is implemented, the objects are said to be persistent.[1]

Overview edit

Implementation-specific details of storage drivers are generally wrapped in an API in the programming language in use, exposing methods to interact with the storage medium in a way which is simpler and more in line with the paradigms of surrounding code.

The following is a simple example, written in C# code, to execute a query written in SQL using a database engine.

var sql = "SELECT id, first_name, last_name, phone, birth_date, sex, age FROM persons WHERE id = 10"; var result = context.Persons.FromSqlRaw(sql).ToList(); var name = result[0]["first_name"]; 

In contrast, the following makes use of an ORM-job API which makes it possible to write code that naturally makes use of the features of the language.

var person = repository.GetPerson(10); var firstName = person.GetFirstName(); 

The case above makes use of an object representing the storage repository and methods of that object. Other frameworks might provide code as static methods, as in the example below, and yet other methods may not implement an object-oriented system at all. Often the choice of paradigm is made for the best fit of the ORM into the surrounding language's design principles.

var person = Person.Get(10); 

Comparison with traditional data access techniques edit

Compared to traditional techniques of exchange between an object-oriented language and a relational database, ORM often reduces the amount of code that needs to be written.[2]

Disadvantages of ORM tools generally stem from the high level of abstraction obscuring what is actually happening in the implementation code. Also, heavy reliance on ORM software has been cited as a major factor in producing poorly designed databases.[3]

Object-oriented databases edit

Another approach is to use an object-oriented database management system (OODBMS) or document-oriented databases such as native XML databases that provide more flexibility in data modeling. OODBMSs are databases designed specifically for working with object-oriented values. Using an OODBMS eliminates the need for converting data to and from its SQL form, as the data is stored in its original object representation and relationships are directly represented, rather than requiring join tables/operations. The equivalent of ORMs for document-oriented databases are called object-document mappers (ODMs).

Document-oriented databases also prevent the user from having to "shred" objects into table rows. Many of these systems also support the XQuery query language to retrieve datasets.

Object-oriented databases tend to be used in complex, niche applications. One of the arguments against using an OODBMS is that it may not be able to execute ad-hoc, application-independent queries.[citation needed] For this reason, many programmers find themselves more at home with an object-SQL mapping system, even though most object-oriented databases are able to process SQL queries to a limited extent. Other OODBMS provide replication to SQL databases, as a means of addressing the need for ad-hoc queries, while preserving well-known query patterns.[citation needed]

Challenges edit

A variety of difficulties arise when considering how to match an object system to a relational database. These difficulties are referred to as the object–relational impedance mismatch.[4]

An alternative to implementing ORM is use of the native procedural languages provided with every major database. These can be called from the client using SQL statements. The Data Access Object (DAO) design pattern is used to abstract these statements and offer a lightweight object-oriented interface to the rest of the application.[5]

See also edit

References edit

  1. ^ a b "What is Object/Relational Mapping?". Hibernate Overview. JBOSS Hibernate. Retrieved 27 January 2022.
  2. ^ Douglas Barry, Torsten Stanienda, "Solving the Java Object Storage Problem," Computer, vol. 31, no. 11, pp. 33-40, Nov. 1998, Excerpt at https://www.service-architecture.com/articles/object-relational-mapping/transparent-persistence-vs-jdbc-call-level-interface.html Lines of code using O/R are only a fraction of those needed for a call-level interface (1:4). For this exercise, 496 lines of code were needed using the ODMG Java Binding compared to 1,923 lines of code using JDBC.
  3. ^ Josh Berkus, "Wrecking Your Database", Computer, Aug. 2009, https://www.toolbox.com/tech/data-management/blogs/wrecking-your-database-080509/
  4. ^ Object–Relational Mapping Revisited - A Quantitative Study on the Impact of Database Technology on O/R Mapping Strategies. M Lorenz, JP Rudolph, G Hesse, M Uflacker, H Plattner. Hawaii International Conference on System Sciences (HICSS), 4877-4886 (DOI:10.24251/hicss.2017.592)
  5. ^ Feuerstein, Steven; Bill Pribyl (September 1997). "Oracle PL/SQL Programming". 18.5 Modifying Persistent Objects. Retrieved 23 August 2011.{{cite web}}: CS1 maint: location (link)

External links edit

object, relational, mapping, confused, with, object, role, modeling, this, article, needs, additional, citations, verification, please, help, improve, this, article, adding, citations, reliable, sources, unsourced, material, challenged, removed, find, sources,. Not to be confused with Object role modeling This article needs additional citations for verification Please help improve this article by adding citations to reliable sources Unsourced material may be challenged and removed Find sources Object relational mapping news newspapers books scholar JSTOR May 2009 Learn how and when to remove this message Object relational mapping ORM O RM and O R mapping tool in computer science is a programming technique for converting data between a relational database and the heap of an object oriented programming language This creates in effect a virtual object database that can be used from within the programming language In object oriented programming data management tasks act on objects that combine scalar values into objects For example consider an address book entry that represents a single person along with zero or more phone numbers and zero or more addresses This could be modeled in an object oriented implementation by a Person object with an attribute field to hold each data item that the entry comprises the person s name a list of phone numbers and a list of addresses The list of phone numbers would itself contain PhoneNumber objects and so on Each such address book entry is treated as a single object by the programming language it can be referenced by a single variable containing a pointer to the object for instance Various methods can be associated with the object such as methods to return the preferred phone number the home address and so on By contrast relational databases such as SQL group scalars into tuples which are then enumerated in tables Tuples and objects have some general similarity in that they are both ways to collect values into named fields such that the whole collection can be manipulated as a single compound entity They have many differences though in particular lifecycle management row insertion and deletion versus garbage collection or reference counting references to other entities object references versus foreign key references and inheritance non existent in relational databases As well objects are managed on heap and are under full control of a single process while database tuples are shared and must incorporate locking merging and retry Object relational mapping provides automated support for mapping tuples to objects and back while accounting for all of these differences 1 The heart of the problem involves translating the logical representation of the objects into an atomized form that is capable of being stored in the database while preserving the properties of the objects and their relationships so that they can be reloaded as objects when needed If this storage and retrieval functionality is implemented the objects are said to be persistent 1 Contents 1 Overview 2 Comparison with traditional data access techniques 3 Object oriented databases 4 Challenges 5 See also 6 References 7 External linksOverview editImplementation specific details of storage drivers are generally wrapped in an API in the programming language in use exposing methods to interact with the storage medium in a way which is simpler and more in line with the paradigms of surrounding code The following is a simple example written in C code to execute a query written in SQL using a database engine var sql SELECT id first name last name phone birth date sex age FROM persons WHERE id 10 var result context Persons FromSqlRaw sql ToList var name result 0 first name In contrast the following makes use of an ORM job API which makes it possible to write code that naturally makes use of the features of the language var person repository GetPerson 10 var firstName person GetFirstName The case above makes use of an object representing the storage repository and methods of that object Other frameworks might provide code as static methods as in the example below and yet other methods may not implement an object oriented system at all Often the choice of paradigm is made for the best fit of the ORM into the surrounding language s design principles var person Person Get 10 Comparison with traditional data access techniques editCompared to traditional techniques of exchange between an object oriented language and a relational database ORM often reduces the amount of code that needs to be written 2 Disadvantages of ORM tools generally stem from the high level of abstraction obscuring what is actually happening in the implementation code Also heavy reliance on ORM software has been cited as a major factor in producing poorly designed databases 3 Object oriented databases editAnother approach is to use an object oriented database management system OODBMS or document oriented databases such as native XML databases that provide more flexibility in data modeling OODBMSs are databases designed specifically for working with object oriented values Using an OODBMS eliminates the need for converting data to and from its SQL form as the data is stored in its original object representation and relationships are directly represented rather than requiring join tables operations The equivalent of ORMs for document oriented databases are called object document mappers ODMs Document oriented databases also prevent the user from having to shred objects into table rows Many of these systems also support the XQuery query language to retrieve datasets Object oriented databases tend to be used in complex niche applications One of the arguments against using an OODBMS is that it may not be able to execute ad hoc application independent queries citation needed For this reason many programmers find themselves more at home with an object SQL mapping system even though most object oriented databases are able to process SQL queries to a limited extent Other OODBMS provide replication to SQL databases as a means of addressing the need for ad hoc queries while preserving well known query patterns citation needed Challenges editA variety of difficulties arise when considering how to match an object system to a relational database These difficulties are referred to as the object relational impedance mismatch 4 An alternative to implementing ORM is use of the native procedural languages provided with every major database These can be called from the client using SQL statements The Data Access Object DAO design pattern is used to abstract these statements and offer a lightweight object oriented interface to the rest of the application 5 See also editList of object relational mapping software Comparison of object relational mapping software AutoFetch automatic query tuning Common Object Request Broker Architecture CORBA Object database Object persistence Object relational database Object relational impedance mismatch Relational model SQL Structured Query Language Java Data Objects JDO Java Persistence API JPA now Jakarta Persistence Service Data Objects Entity Framework Active record pattern Data mapper pattern Single Table InheritanceReferences edit a b What is Object Relational Mapping Hibernate Overview JBOSS Hibernate Retrieved 27 January 2022 Douglas Barry Torsten Stanienda Solving the Java Object Storage Problem Computer vol 31 no 11 pp 33 40 Nov 1998 Excerpt at https www service architecture com articles object relational mapping transparent persistence vs jdbc call level interface html Lines of code using O R are only a fraction of those needed for a call level interface 1 4 For this exercise 496 lines of code were needed using the ODMG Java Binding compared to 1 923 lines of code using JDBC Josh Berkus Wrecking Your Database Computer Aug 2009 https www toolbox com tech data management blogs wrecking your database 080509 Object Relational Mapping Revisited A Quantitative Study on the Impact of Database Technology on O R Mapping Strategies M Lorenz JP Rudolph G Hesse M Uflacker H Plattner Hawaii International Conference on System Sciences HICSS 4877 4886 DOI 10 24251 hicss 2017 592 Feuerstein Steven Bill Pribyl September 1997 Oracle PL SQL Programming 18 5 Modifying Persistent Objects Retrieved 23 August 2011 a href Template Cite web html title Template Cite web cite web a CS1 maint location link External links editAbout ORM by Anders Hejlsberg Mapping Objects to Relational Databases O R Mapping In Detail by Scott W Ambler Retrieved from https en wikipedia org w index php title Object relational mapping amp oldid 1213905828, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.