OR Mapping
No edit summary
No edit summary
 
(5 intermediate revisions by 2 users not shown)
Line 15: Line 15:
* '''Security''': ORM helps prevent SQL injection attacks by parameterizing queries.
* '''Security''': ORM helps prevent SQL injection attacks by parameterizing queries.
* '''Abstraction''': Developers work with objects, abstracting away low-level database details.
* '''Abstraction''': Developers work with objects, abstracting away low-level database details.
* '''Popular ORM Frameworks''':
ORM simplifies database interactions by allowing developers to work with objects in their code, while the ORM handles the underlying database operations. It’s a powerful tool for building robust and maintainable software systems.  
* '''Hibernate (Java)''': A widely used ORM framework for Java applications.
* '''Entity Framework (.NET)''': Microsoft’s ORM framework for .NET applications.
* '''Django ORM (Python)''': Integrated with the Django web framework.
* '''Sequelize (Node.js)''': ORM for Node.js applications.
* '''SQLAlchemy (Python)''': A flexible and powerful ORM library for Python.


ORM simplifies database interactions by allowing developers to work with objects in their code, while the ORM handles the underlying database operations. It’s a powerful tool for building robust and maintainable software systems. 🚀📊
==== Other OR mappers ====
[https://learn.microsoft.com/en-us/aspnet/entity-framework Entity framework] from Microsoft, [https://hibernate.org/orm/ Hibernate] for Java or .net or Django's ORM are all OR mappers, although simpler than MDriven's OR mapper and all lacking modelling support.


'''Learn more here:''' https://builtin.com/data-science/object-relational-mapping
'''Learn more here:''' [[wikipedia:Object–relational_mapping|Object–relational mapping on Wikipedia]]
 
See also: [[Documentation:Type mapping, OR-Mapping|Type mapping, OR-Mapping]], [[Documentation:Working with Code and Persistence Mapping|Working with Code and Persistence Mapping]]

Latest revision as of 07:30, 23 May 2024

Object-relational mapping (also ORM and O/R Mapping) is a technique used in software engineering to bridge the gap between object-oriented programming (OOP) and relational databases. OR Mapping converts data between a database and an object-oriented programming language.

ORM allows developers to work with database records as if they were objects in their programming language, abstracting away the complexities of SQL queries and database interactions.

How Does ORM Work?

  • Mapping: ORM maps database tables to classes (objects) in the application code.
  • CRUD Operations: Developers can perform CRUD (Create, Read, Update, Delete) operations on objects, and the ORM translates these actions into corresponding SQL statements.
  • Relationships: ORM handles relationships (such as one-to-many, many-to-many) between objects and their associated database tables.

Benefits of ORM:

  • Productivity: Developers can focus on business logic rather than writing raw SQL queries.
  • Portability: ORM makes it easier to switch between different database systems (e.g., MySQL, PostgreSQL, SQLite) without changing application code.
  • Security: ORM helps prevent SQL injection attacks by parameterizing queries.
  • Abstraction: Developers work with objects, abstracting away low-level database details.

ORM simplifies database interactions by allowing developers to work with objects in their code, while the ORM handles the underlying database operations. It’s a powerful tool for building robust and maintainable software systems.

Other OR mappers

Entity framework from Microsoft, Hibernate for Java or .net or Django's ORM are all OR mappers, although simpler than MDriven's OR mapper and all lacking modelling support.

Learn more here: Object–relational mapping on Wikipedia

See also: Type mapping, OR-Mapping, Working with Code and Persistence Mapping

This page was edited more than 8 months ago on 05/23/2024. What links here