0

0

哪个 Python ORM 在 Django 和 SQLAlchemy 之间更好

WBOY

WBOY

发布时间:2024-01-13 20:03:04

|

651人浏览过

|

来源于Linux就该这么学

转载

什么是 ORM?

在介绍 Python 的 ORM 框架(Django 和 SQLAlchemy)不同之前,我们先要确保完全理解 ORM 框架的用途。

ORM 代表对象关系映射(Object Relational Mapping)。让我们依次看看这三个单词,它们正好解释了 ORM在真实环境中的用处:

● 对象 – 这部分表示使用框架的对象和编程语言,例如 Python。

● 关系 – 这部分表示正在使用的 RDBMS (关系数据库管理系统)数据库。其中包括许多流行的关系数据库,而你可能正在使用以下数据库 — MSSQL、MySQL、Oracle数据库、PostgreSQL、MariaDB、PerconaDB、TokuDB。大多数关系数据库之间的共同点是它们的关系结构(表、列,键、约束等)。

● 映射 – 最后这部分表示前两部分对象和数据表之间的桥梁和连接。

因此可以得出的结论是 ORM 是为了将编程语言与数据库之间相连,以便简化创建依赖于数据的应用程序过程。

Django 和 SQLAlchemy 之间比较 活动记录 vs 数据映射

Django ORM 采用活动记录实现 — 大多数 ORM 中能看到这种实现。基本上也可以说是数据库中每一行都直接映射到代码中的对象,反之亦然。ORM 框架(如 Django) 不需要为了在代码中使用属性而预先定义架构,只需要使用它们,因为框架可以通过查看数据库架构“理解”结构。此外,也可以只保存记录到数据库,因为它也映射到表中的特定行。

SQLAlchemy 采用数据映射实现 — 当使用这种方式实现时,数据库结构和对象结构之间存在间隙(它们不像活动记录的实现是 1:1)。大多数情况下,必须使用另外的持久层来保持与数据库的交互(例如保存对象)。因此当采用活动记录实现的时候不能只调用 save() 方法(反对观点),但另一方面,代码不需要知道数据库中整个关系结构的运行,因为代码和数据库之间没有直接关系。

那么它们之间谁获胜了呢?都没有。这取决于你要实现什么。我相信如果你的应用程序大多是 CRUD (创建、读取、更新、删除)程序,而在不同数据实体之间没有使用困难且复杂规则,那么应该采用活动记录实现(Django)。它将帮助你轻松快速地为产品设置 MVP,而不会有任何困难。如果有许多“业务规则”和限制条件,最好采用数据映射模型,因为它不会捆绑并强迫严格遵照活动记录来考量。

使用复杂查询

在某些情况下,Django 和 SQLAlchemy 可以同时使用。现实环境中我多次见到主用例是 Django 用于所有常规 CRUD 操作,而 SQLAlchemy 用于更复杂的查询,通常是只读查询。

有关这方面更多的信息和实例,可以看看 BetterWorks 工程博客(我们没有任何联系,但不管怎样,我们喜欢他们的博客)。

主键自动生成

两个框架之间的另一个不同是 Django 能为表自动创建主键, SQLAlchemy 却做不到。必须手动为每张表创建主键。权衡利弊 — 你认为哪种框架最清楚符合表的主键?根据团队的知识和经验,可以自行决定。

自动提交

默认情况下,Django 会自动提交, SQLAlchemy 却不行。自动提交会影响使用框架的方式(事务、回滚等)。

支持的数据库

Django 和 SQLAlchemy 都能用于 MySQL、PostgreSQL、Oracle 和 SQLite。如果你正在使用 MSSQL,则应该使用 SQLAlchemy,因为它完全支持 MSSQL ,并且也可以找到更多相关的信息和文档。

学习曲线

在网上有一个普遍的观点,认为 Django 更容易学习。这是显而易见的,由于它通常都用在没有特别复杂的用例上。因此,应该考虑愿意投入多少精力来学习框架,与 SQLAlchemy 交叉学习以便获得更多的灵活性(假使你真的需要它)。

社区规模

毫无疑问,在 Python ORM 框架中 SQLAlchemy 拥有最大的社区。如果社区对你至关重要(我认为它应该是),SQLAlchemy 该是你的选择。这并不说明对于其它框架,你不能找到任何帮助,例如 Django。你也可以获得 bug 修复,从 StackOverflow 得到问题的答案和其它需要的帮助,但概率仅仅比 SQLAlchemy 高。

性能

我认为只在这里写(X 比 Y 快)是不负责任的。由于 ORM 具有如此多特征和功能,并且它们在每个框架中也不同,这将很难得出结论。根据我的经验,使用框架特性的方式,会对应用程序中数据层的整体性能产生极大影响。因此我建议不要通过性能来选择框架,而是应该学习如何合理利用框架。

假如在 ORM 框架中使用原始的 SQL 查询、使用 Jooq 或者只是部分查询不使用 ORM,可以了解 EverSQL 查询优化器,这可能是最简单优化任何查询的方法。

总结

任何比较中,我认为最好把决策权交还给读者。每个用例之间是不同的,不同的技术也可以更适用。看看上面指出的差异,让我们知道你做出了什么决定。

相关文章

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2152

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1663

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号