SQLAlchemy - 什么是declarative_base

时间:2013-03-02 14:01:49

标签: python sqlalchemy

我正在学习sqlalchemy。这是我的初始代码:

文件:user.py

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

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.py和amp;中使用相同的'Base'变量user.py.它创建表。

我的问题是什么是'declarative_base'?

1 个答案:

答案 0 :(得分:26)

declarative_base()是一个工厂函数,它为声明性类定义(在您的示例中分配给Base变量)构造基类。你在user.py中创建的那个与User模型相关联,而另一个(在main.py中)是一个不同的类,并且对模型一无所知,这就是为什么{{1} } call没有创建表。您需要从user.py

导入Base.metadata.create_all()
Base

而不是在main.py中创建新的from user import User, Base 类。