Flask 学习 四 数据库

class Role(db.Model):
    __tablename__='roles'
    id = db.Column(db.Integer,primary_key=True)
    name = db.Column(db.String(64),unique=True)
    users = db.relationship('User',backref='role')
    def __repr__(self):
        return '<Role %r>'% self.name
class User(db.Model):
    __tablename__ = 'users'
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(64), unique=True,index=True)
    role_id=db.Column(db.Integer,db.ForeignKey('role.id'))
    def __repr__(self):
        return '<User %r>' % self.username
设置SQLALCHEMY_TRACK_MODIFICATIONS 为True或False
报错:FSADeprecationWarning:
需要:提示给的839行,在前面几行的位置有这样的setdefault, 
把None改为True;:

视图函数中操作数据库

@app.route('/', methods=['get', 'post'])
def index1():
    #name = None
    form = NameForm()
    if form.validate_on_submit():
        user = User.query.filter_by(username=form.name.data).first()
        if user is None:
            user = User(username=form.name.data)
            db.session.add(user)
            session['known']=False
        else:
            session['known'] = True
        session['name']=form.name.data
        form.name.data=''
        return redirect(url_for('index1'))
    return render_template('index.html', name=session.get('name'), form=form, known=session.get('known',False))

 

# 集成python shell
def make_shell_context():
    return dict(app=app, db=db, User=User, Role=Role)
manager.add_command("shell", Shell(make_context=make_shell_context))

数据库迁移 

pip install flask-migrate

from flask_migrate import Migrate,MigrateCommand

# 数据库迁移
migrate = Migrate(app,db)
manager.add_command('db',MigrateCommand)

# init命令创建迁移仓库
python flask_blog.py db init

# 创建迁移脚本
python flask_blog.py db migrate -m 'initial migration'

# 更新数据库

python flask_blog.py db upgrade

 

转载于:https://www.cnblogs.com/Erick-L/p/6880289.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值