Подтвердить что ты не робот

SQLAlchemy - что такое declarative_base

Я изучаю 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:[email protected]: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()" в другой модуль и использую ту же переменную "Base" в main.py и user.py. Он создает таблицу.

Мой вопрос: что такое 'declarative_base'?

4b9b3361

Ответ 1

declarative_base() - это функция factory, которая строит базовый класс для декларативных определений классов (который присваивается переменной Base в ваш пример). Тот, который вы создали в user.py, связан с моделью User, а другой (в main.py) - это другой класс и ничего не знает о ваших моделях, поэтому вызов Base.metadata.create_all() не создавал Таблица. Вам нужно импортировать Base из user.py

from user import User, Base

вместо создания нового класса Base в main.py.