我开始玩一些对象关系映射器(特别是Pony ORM)。
在Pony中,所有实体定义都继承自db.Entity
该类。然而,为了做到这一点,当然db
需要先在某个地方创建对象。(db.Entity
有点类似于sqlalchemy中的声明性基础,所以我相信我下面的问题对sqlalchemy也同样有效)
我在 Pony ORM 文档中看到的所有示例都提供了内联示例,其中在db
声明实体之前在解释器提示中简单地声明了 Database 对象。
这给我留下了一个问题:我应该在“真实”项目中在哪里创建我的 db 对象?
特别考虑我想将我的实体定义与我实际使用这些实体的位置分开的情况(比如我只想构建一个好的 ORM 包装器包来访问数据库,然后应该在多个不同的其他项目中使用它)。然后我可能希望用户提供根据db
他们的需要配置的自己的对象,以便访问数据库。
一些示例代码:
假设我有一个存储人员和地址的数据库,我的包my_orm
应该为数据库提供一个 ORM,然后将用于app.py
:
我的_orm/初始化.py
from my_orm.person import Person
from my_orm.address import Address
my_orm/person.py:
from pony.orm import Required
class Person(db.Entity): # Where should `db` be defined?
name = Required(str)
age = Required(int)
my_orm/address.py:
from pony.orm import Required
class Address(db.Entity): # Where should `db` be defined?. Must be the same `db` object as in person.py
street_name = Required(str)
zip_code = Required(int)
应用程序.py
from pony.orm import Database
db = Database()
import my_orm
除了已经看起来很丑,因为它将导入与数据库的创建混合在一起,这也会抛出错误NameError: name 'db' is not defined
。那么我应该怎么做呢?