首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLAlchemy -什么是declarative_base

SQLAlchemy -什么是declarative_base
EN

Stack Overflow用户
提问于 2013-03-02 22:01:49
回答 1查看 42.1K关注 0票数 43

我正在学习sqlalchemy

以下是我的初始代码:

user.py

代码语言:javascript
复制
from sqlalchemy import Column, Integer, Sequence, String
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()

class User(Base):
   __tablename__ = 'users'
   id = Column(Integer,Sequence('user_seq'), primary_key=True)
   username = Column(String(50), unique=True)
   fullname = Column(String(150))
   password = Column(String(50))
   def __init__(self, name, fullname, password):
      self.name = name
      self.fullname = fullname
      self.password = password

main.py

代码语言:javascript
复制
from sqlalchemy.orm import sessionmaker
from sqlalchemy import create_engine
from user import User
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()

if __name__ == '__main__':
   engine = create_engine('mysql://root:password@127.0.0.1:3306/test', echo=True)
   Base.metadata.create_all(engine, checkfirst=True)
   Session = sessionmaker(bind=engine)
   session = Session()
   ed_user = User('ed', 'Ed Jones', 'edspassword')
   session.add(ed_user)
   session.commit()

当我运行main.py时,它不会自动创建表,并且在session.commit()上给了我一个异常。

此外,当我将Base = declarative_base()行移动到任何不同的模块,并在main.pyuser.py中使用相同的Base变量时,它会创建表。

我的问题是:“什么是declarative_base?”

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-03-02 23:25:58

declarative_base()是一个工厂函数,它为声明性类定义构造基类(在您的示例中,这个基类被分配给Base变量)。您在user.py中创建的表与User模型相关联,而另一个(在main.py中)是一个不同的类,并且对您的模型一无所知,这就是Base.metadata.create_all()调用没有创建表的原因。您需要从user.py导入Base

代码语言:javascript
复制
from user import User, Base

而不是在main.py中创建新的Base类。

票数 49
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15175339

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档