栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

SQLAlchemy create_all()不创建表

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SQLAlchemy create_all()不创建表

您应该在

create_all()
调用之前放置模型类,如下所示:

from flask import Flaskfrom flask_sqlalchemy import SQLAlchemyapp = Flask(__name__)app.config['SQLALCHEMY_DATAbase_URI'] = 'postgresql+psycopg2://login:pass@localhost/flask_app'db = SQLAlchemy(app)class User(db.Model):    id = db.Column(db.Integer, primary_key=True)    username = db.Column(db.String(80), unique=True)    email = db.Column(db.String(120), unique=True)    def __init__(self, username, email):        self.username = username        self.email = email    def __repr__(self):        return '<User %r>' % self.usernamedb.create_all()db.session.commit()admin = User('admin', 'admin@example.com')guest = User('guest', 'guest@example.com')db.session.add(admin)db.session.add(guest)db.session.commit()users = User.query.all()print users

如果您的模型是在单独的模块中声明的,请在调用之前将其导入

create_all()

说,

User
模型在名为的文件中
models.py

from flask import Flaskfrom flask_sqlalchemy import SQLAlchemyapp = Flask(__name__)app.config['SQLALCHEMY_DATAbase_URI'] = 'postgresql+psycopg2://login:pass@localhost/flask_app'db = SQLAlchemy(app)# See important note belowfrom models import Userdb.create_all()db.session.commit()admin = User('admin', 'admin@example.com')guest = User('guest', 'guest@example.com')db.session.add(admin)db.session.add(guest)db.session.commit()users = User.query.all()print users

重要说明: 在初始化

db
对象之后导入模型很重要,因为在
models.py
_中,您还需要
db
从此模块导入对象。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/637793.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号