【问题标题】:SQLAlchemy - create table templateSQLAlchemy - 创建表模板
【发布时间】:2011-10-11 19:07:55
【问题描述】:

我刚开始使用 SQLAlchemy,我一直在想……我的模型中将有很多表。我希望我的模型中的每个表都有自己的文件。

我目前正在使用以下代码:

from sqlalchemy import MetaData
from sqlalchemy.orm import scoped_session, sessionmaker
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.dialects import postgresql
import sqlalchemy as sa

__all__ = ['Session', 'engine', 'metadata']

# SQLAlchemy database engine. Updated by model.init_model()
engine = None

# SQLAlchemy session manager. Updated by model.init_model()
Session = scoped_session(sessionmaker())

# Global metadata. If you have multiple databases with overlapping table
# names, you'll need a metadata for each database
metadata = MetaData()

# declarative table definitions
Base = declarative_base()
Base.metadata = metadata

schema = 'srbam_dev'

在 meta.py 中

_init_.py

之后
"""The application's model objects"""
import sqlalchemy as sa
from sqlalchemy import orm

from models import meta
from models.filers import Filer
from models.vfilers import Vfiler
from models.filer_options import FilerOption

def init_models(engine):
    """Call me before using any of the tables or classes in the model"""
    ## Reflected tables must be defined and mapped here
    #global reflected_table
    #reflected_table = sa.Table("Reflected", meta.metadata, autoload=True,
    #                           autoload_with=engine)
    #orm.mapper(Reflected, reflected_table)
    #
    meta.engine = sa.create_engine(engine)
    meta.Session.configure(bind=meta.engine)

    class Basic_Table(object):
        id = sa.Column(
            postgresql.UUID(),
            nullable=False,
            primary_key=True
            )
        created = sa.Column(
            sa.types.DateTime(True),
            nullable=False
            )
        modified = sa.Column(
            sa.types.DateTime(True),
            nullable=False
            )

然后跟随我所有的模型

from models.meta import Base
from models.meta import Basic_Table
from models.meta import schema
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql

class Filer(Base,Basic_Table):

这很好用,只要我不开始在表上使用一些外键,一旦我使用外键就说

sqlalchemy.exc.NoReferencedTableError: Foreign key associated with column 't_vfilers.filer_id' could not find table 't_filers' with which to generate a foreign key to target column 'id'

我尝试直接在 Filer 类中定义 id 键(并从声明中删除 Basic_Table),但这并不能解决问题。

我创建数据库的代码如下所示 #!/usr/bin/python 导入配置解析器 从 sqlalchemy.engine.url 导入 URL 从模型导入 *

config = ConfigParser.RawConfigParser()
config.read('conf/core.conf')
db_url = URL(
    'postgresql+psycopg2',
    config.get('database','username'),
    config.get('database','password'),
    config.get('database','host'),
    config.get('database','port'),
    config.get('database','dbname')
    )

init_models(db_url)
meta.Base.metadata.drop_all(bind=meta.engine)
meta.Base.metadata.create_all(bind=meta.engine)

有人知道如何解决这个问题吗?

【问题讨论】:

  • 异常发生在哪里?
  • 我可以看看你是如何定义你的 ForeignKey 约束的。我也认为如果这段代码都在一个文件中,它是否有效? (当然有适当的改变)?
  • 该错误似乎表明找不到Table,而不是Column。我在这里猜测,但尝试将 Filer 导入到您为其定义 FK 的模块中,然后查看错误是否已更改。

标签: python sqlalchemy


【解决方案1】:

Marek,做一件事,尝试定义外键和架构名称,即“test.t_vfilers.filer_id”(这里“test”是架构名称),这将解决问题。

【讨论】:

    【解决方案2】:

    您是否记得导入包含模型的不同模块。 在我的 init.py 底部有很多:

    from comparty3.model.users import User, UserGroup, Permission
    from comparty3.model.pages import PageGroup, Page
    etc...
    

    如果这不是问题,那我不确定;但是您是否尝试过改变:

    metadata = MetaData()
    
    # declarative table definitions
    Base = declarative_base()
    Base.metadata = metadata
    

    到:

    # declarative table definitions
    Base = declarative_base()
    metadata = Base.metadata
    

    我在这里猜测,但可能是 declarative_base() 创建了一个特殊的元数据对象。 这就是它在我的 pylons 项目中的定义方式(我猜你的代码也是来自)。

    【讨论】:

    • 您好,是的,我正在导入我的 init.py 文件中的所有类。我试图更改为您提到的示例,但没有任何改变。
    猜你喜欢
    • 2021-08-23
    • 2019-07-17
    • 2016-08-13
    • 1970-01-01
    • 2019-06-04
    • 1970-01-01
    • 2017-11-29
    • 1970-01-01
    • 2014-01-11
    相关资源
    最近更新 更多