46

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

用户.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

主文件

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.pyBase中使用相同的变量时- 它会创建表。

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

4

1 回答 1

51

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

from user import User, Base

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

于 2013-03-02T15:25:58.253 回答