gpt4 book ai didi

python - SQLAlchemy - 什么是 declarative_base

转载 作者:IT老高 更新时间:2023-10-28 22:19:02 27 4
gpt4 key购买 nike

我正在学习 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

ma​​in.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()

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

另外,当我将行 Base = declarative_base() 移动到任何不同的模块并在 ma​​in.py 中使用相同的 Base 变量和在 user.py - 它创建表。

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

最佳答案

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

from user import User, Base

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

关于python - SQLAlchemy - 什么是 declarative_base,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15175339/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com