ORM是什么?

ORM,全称为Object Relational Mapping(对象关系映射),是一种编程技术。

        ORM主要用于在面向对象的编程语言关系型数据库管理系统之间建立桥梁。ORM框架的核心功能之一就是不仅可以将关系型数据库中的数据转化为程序中的对象模型,还可以将对象模型转化回数据库中的数据

        一、在传统的数据库应用中

        在传统的数据库应用中开发者需要编写SQL语句来操作数据库,而这些SQL语句与面向对象的编程语言的语法和概念有很大的差异。

        二、ORM框架

        ORM技术则允许开发者以面向对象的方式操作数据,例如创建、读取、更新和删除对象,而不需要直接写SQL语句。ORM框架会自动处理这些对象与数据库表之间的映射关系。在ORM中,数据库表被视为对象类,表中的每一条记录被视为该类的一个实例,表的列则映射为对象的属性。当从数据库中检索数据时,ORM框架会自动将数据行转换为相应的对象实例。同样,当对对象进行更改并将其保存回数据库时,ORM框架会负责将对象状态的改变转换为适当的SQL更新语句。

        三、ORM的优点

        1.提高开发效率:开发者可以专注于业务逻辑而不是SQL语句的编写。

        2.代码可读性:使用面向对象的语法更符合现代编程的风格,使得代码更加清晰。

        3.减少错误:自动化的映射减少了由于SQL语法错误或SQL注入等问题导致的bug。

        4.数据库无关性:许多ORM框架支持多种数据库(如MySQL、PostgreSQL、SQLite等),这意味着更换数据库时,应用的大部分代码无需修改。

        5.事务管理:ORM框架通常包含事务管理功能,可以自动开启和提交事务,或者在出现错误时回滚事务,从而保证数据的一致性和完整性。

        6.缓存机制:许多ORM实现了缓存机制,可以存储最近访问的数据,避免不必要的数据库查询,从而提高性能。

        7.连接池:ORM框架往往包含连接池功能,可以复用数据库连接,减少建立和断开连接的开销,提高数据库访问效率。

        四、ORM的缺点

        1.性能开销:ORM在自动化运行时需要解析和生成SQL语句,这可能不如直接使用SQL语句高效。

        2.灵活性受限:ORM可能不适合所有类型的查询,尤其是非常复杂的查询,ORM可能无法提供完全的替代方案,这时直接使用SQL可能更为合适。

        3.学习曲线:使用ORM框架需要额外的学习成本。

        五、ORM的转换步骤

        当你在应用中创建、修改或删除一个对象时,ORM框架会跟踪这些对象的状态变化。当你决定将这些更改保存到数据库时,ORM会生成相应的SQL语句来执行这些操作,例如INSERT、UPDATE或DELETE语句,以此来反映对象模型中的变化。

        以下是使用ORM将对象模型转化为数据库数据的一般步骤:

        1. 对象创建:在应用中创建一个新的对象实例,通常对应于数据库中的新记录。

        2. 对象持久化:调用ORM提供的方法(如'save()')将对象保存到数据库。ORM会检测对象的状态,并执行INSERT语句来插入新的记录

        3. 对象更新:在应用中修改已存在的对象的属性。当调用'save()'或类似方法时,ORM会检测到属性的变化,并执行更新数据库记录所需的UPDATE语句。

        4. 对象删除:如果决定从数据库中移除一个对象,你可以调用ORM提供的删除方法(如'delete()')。ORM会生成DELETE语句,以从数据库中移除对应的记录

        六、ORM在现代Web开发中非常流行,常见的ORM框架包括:

        1.Java的Hibernate

        2.Python的Django ORM

        3.NET的Entity Framework

        4.Ruby on Rails的ActiveRecord

        5.PHP的Doctrine

        ...


谢谢支持!成为一位优秀的程序员,道阻且长,你我共勉。
  • 33
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值