SQLAlchemy - 什么是declarative_base

62 投票
1 回答
75066 浏览
提问于 2025-04-17 17:41

我正在学习 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.pyuser.py 中使用同一个 Base 变量时,它就能创建表了。

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

1 个回答

63

declarative_base() 是一个工厂函数,用来创建一个基础类,这个基础类是用来定义模型的(在你的例子中,这个基础类被赋值给了 Base 变量)。你在 user.py 中创建的这个基础类是和 User 模型关联的,而在 main.py 中创建的那个基础类是一个不同的类,它对你的模型一无所知,所以 Base.metadata.create_all() 这个调用没有创建表。你需要从 user.py 中导入 Base

from user import User, Base

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

撰写回答