Tôi đang học sqlalchemy. Đây là mã ban đầu của tôi:SQLAlchemy - declarative_base
File: 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
file 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()
Bây giờ khi tôi chạy main.py. Nó sẽ không tạo bảng tự động & cho tôi ngoại lệ trên 'session.commit()'. Bây giờ khi tôi di chuyển dòng 'Base = declarative_base()' sang mô-đun khác nhau & sử dụng biến 'Cơ sở' giống nhau trong main.py & user.py. Nó tạo ra bảng.
Câu hỏi của tôi là 'declarative_base' là gì?
Lỗi bạn nhận được khi thực hiện theo cách khác là gì? –