数据库

DB-API

Python数据库API(DB-API)定义了一个Python数据库访问模块的标准接口。它的文档在 PEP 249 可以查看。 几乎所有Python数据库模块,诸如 sqlite3psycopg 以及 mysql-python 都遵循这个接口。

关于如何与遵守这一接口的模块交互的教程可以在这里找到: 这里 以及 这里

SQLAlchemy

SQLAlchemy 是一个流行的数据库工具。不像很多 数据库库,它不仅提供一个ORM层,而且还有一个通用API来编写避免SQL的数据库无关代码。

$ pip install sqlalchemy

Django ORM

Django ORM 是 Django 用来进行数据库访问的接口。

它的思想建立在 models , 之上。这是一个致力于简化Python中数据操作的抽象层。

基础:

  • 每个model是django.db.models.Model的子类。
  • model的每个属性表示数据库的域(field)。
  • Django给你一个自动生成的数据库访问API,参见 Making queries

peewee

peewee 是另一个ORM,它致力于轻量级和支持Python2.6+与3.2+默认支持的 SQLite,MySQL以及Postgres。 model layer 与Django ORM类似并且它拥有 SQL-like methods 来查询数据。除了将SQLite,MySQL以及Postgres变为开箱即用,还有进一步的扩展功能可以在这里找到: collection of add-ons

PonyORM

PonyORM 是一个ORM,它使用与众不同的方法查询数据库,有别于 使用类似SQL的语言或者布尔表达式,它使用Python的生成器达到目的。而且还有一个图形化 schema编辑器生成PonyORM实体。它支持Python2.6+与3.3+并且可以连接SQLite,MySQL,Postgres与Oracle。

SQLObject

SQLObject 是另一个ORM。它支持广泛的数据库,常见的 MySQL,Postgres以及SQLite与更多的特别系统如SAP DB,SyBase与MSSQL。它只支持Python 2