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)