SQLAlchemy是
Python下的一款开源软件。提供了
SQL工具包及对象关系映射(
NHibernate)工具,使用MIT许可证发行。SQLAlchemy“采用简单的Python语言,为高效和高性能的数据库访问设计,实现了完整的企业级持久模型”。SQLAlchemy的理念是,SQL数据库的量级和性能重要于对象集合;而对象集合的抽象又重要于表和行。因此,SQLAlchemy采用了类似于Java里Hibernate的数据映射模型,而不是其他ORM框架采用的Active Record模型。不过,
Elixir和declarative等可选
插件可以让用户使用声明语法。SQLAlchemy首次发行于2006年2月,并迅速地在
Python社区中最广泛使用的
NHibernate工具之一,不亚于
Django的ORM框架。
对象关系映射器(Object Relational Mappers,ORM)在过去数年吸引了不少人的目光。主要原因是 ORM 经常会在 Web 应用程序框架中被提起,因为它是快速开发(Rapid Development)栈中的关键组件。Django 和 Ruby on Rails 等 Web 框架采用了设计一个独立栈的方法,将自主开发的 ORM 紧密集成到该框架中。而其他框架,如 Pylons、Turbogears 和 Grok,则采用更加基于组件的架构结合可交换的第三方组件。两种方法都有各自的优势:紧密集成允许非常连贯的体验(如果问题映射到框架),而基于组件的架构则允许最大的设计灵活性。但是,本文的主题并不是 Web 框架;而是 SQLAlchemy。
SQLAlchemy 在构建在 WSGI 规范上的下一代
Python Web 框架中得到了广泛应用,它是由 Mike Bayer 和他的核心开发人员团队开发的一个单独的项目。使用 SQLAlchemy等独立
NHibernate 的一个优势就是它允许开发人员首先考虑数据模型,并能决定稍后可视化数据的方式(采用命令行工具、Web 框架还是 GUI 框架)。这与先决定使用 Web 框架或 GUI 框架,然后再决定如何在框架允许的范围内使用数据模型的开发方法极为不同。
SQLAlchemy 的一个目标是提供能兼容众多数据库(如
SQLite、
MySQL、Postgres、
Oracle数据库、MS-SQL、SQLServer 和 Firebird)的企业级持久性模型。SQLAlchemy 正处于积极开发阶段,当前最新的 API 将围绕版本 0.5 设计。请参阅参考资料部分,获取官方 API 文档、教程和 SQLAlchemy 书籍的链接。
SQLAlchemy 取得成功的一个证明就是围绕它已建立了丰富的社区。针对 SQLAlchemy 的扩展和
插件包括:declarative、Migrate、Elixir、SQLSoup、django-sqlalchemy、DBSprockets、FormAlchemy 和 z3c.sqlalchemy。
SQLAlchemy的灵活性也体现在其提供的编程示例中。例如,定义电影和导演之间的多对一关系时,可以通过用户定义的
Python类来创建对应的数据库表格,并通过简单的操作来插入和查询数据。这些操作包括从关联的任何一方创建实例,以及为延迟加载和预先加载自动生成
SQL查询。这种灵活性允许开发者根据需要进行延迟加载或预先加载,从而优化性能和资源利用。
在使用SQLAlchemy时,首先需要定义数据模型。这通常涉及创建Python类并将其映射到数据库表。SQLAlchemy使用声明性基类来自动定义表的元数据。然后,可以使用会话(session)来插入数据,会话负责与数据库的所有交互。数据插入后,可以执行查询来检索数据。SQLAlchemy提供了丰富的查询接口,允许开发者以几乎与写原生
SQL一样的方式来检索数据,同时还提供了对象化的接口来处理结果。
SQLAlchemy的成功也得益于其强大的扩展性和活跃的社区支持。社区贡献的扩展和
插件丰富了SQLAlchemy的生态系统,使其能够更好地集成到各种应用和框架中。这些扩展和插件不仅增强了SQLAlchemy的功能,也提供了更多的选择来满足不同项目的需求。