Flask数据库 Day2

Flask数据库 Day2

1.图书管理案例

用到wtf,一对多管理数据库

author = Author.query.filter(Author.name == author_name).first()

对数据库操作都要用try包裹,包裹防止出错

2.多对多关系演练

唯一点就是:需要添加一张单独的表去记录两张表之间的关系

创建一个单独的表,不继承模型:
tb_Student_Course = db.Table(
‘student_course’,
db.Column(‘student_id’,db.Integer,db.ForeignKey(‘student.id’))
)

添加中间表:
courses = db.relationship(‘Course’,secondary = tb_Student_Course)

不指定lazy relationship会主动去关联的表里把数据查询出来了啦
添加lazy = 'dynamic’就不会主动去查询出值,没有具体的值,只是一个查询对象,我们可以用到的时候再去查询,避免不必要操作,影响性能

3.数据库迁移

依赖flask-migrate库
修改数据库模型,在修改之后更新数据库
flaks-migrate 数据库创表,更新

迁移初始化:生成前一所需文件夹 python
xxx.py db init
生成迁移版本 python xxx.py db migrate
执行迁移(往上迁移)python xxx.py db upgrade

实际操作顺序:
1.python 文件 db init
2.python 文件 db migrate -m"版本名(注释)"
3.python 文件 db upgrade 然后观察表结构
4.根据需求修改模型
5.python 文件 db migrate -m"新版本名(注释)"
6.python 文件 db upgrade 然后观察表结构
7.若返回版本,则利用 python 文件 db history查看版本号
8.python 文件 db downgrade(upgrade) 版本号

4.Flask信号机制

依赖Blinker库
@models_committed.connect_via(app)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值