flask数据库中关系模块

记得导入数据库

在项目开发过程中,会遇到很多数据之间多对多关系的情况,比如:

  • 学生网上选课(学生和课程)
  • 老师与其授课的班级(老师和班级)
  • 用户与其收藏的新闻(用户和新闻)
  • 等等...

所以在开发过程中需要使用 ORM 模型将表与表的多对多关联关系使用代码描述出来。多对多关系描述有一个唯一的点就是:需要添加一张单独的表去记录两张表之间的对应关系

代码演练

  • 定义模型及表
tb_student_course = db.Table('tb_student_course',
                             db.Column('student_id', db.Integer, db.ForeignKey('students.id')),
                             db.Column('course_id', db.Integer, db.ForeignKey('courses.id'))
                             )


class Student(db.Model):
    __tablename__ = "students"
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(64), unique=True)

    courses = db.relationship('Course', secondary=tb_student_course,
                              backref=db.backref('student', lazy='dynamic'),
                              lazy='dynamic')


class Course(db.Model):
    __tablename__ = "courses"
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(64), unique=True)
  • 添加测试数据
if __name__ == '__main__':
    db.drop_all()
    db.create_all()

    # 添加测试数据

    stu1 = Student(name='张三')
    stu2 = Student(name='李四')
    stu3 = Student(name='王五')

    cou1 = Course(name='物理')
    cou2 = Course(name='化学')
    cou3 = Course(name='生物')

    stu1.courses = [cou2, cou3]
    stu2.courses = [cou2]
    stu3.courses = [cou1, cou2, cou3]

    db.session.add_all([stu1, stu2, stu3])
    db.session.add_all([cou1, cou2, cou3])

    db.session.commit()

    app.run(debug=True)

lazy参数的用法

参数lazy决定了什么时候SQLALchemy从数据库中加载数据

  • 如果设置为子查询方式(subquery),则会在加载完Role对象后,就立即加载与其关联的对象,这样会让总查询数量减少,但如果返回的条目数量很多,就会比较慢
  • 设置为 subquery 的话,role.users 返回所有数据列表

  • 另外,也可以设置为动态方式(dynamic),这样关联对象会在被使用的时候再进行加载,并且在返回前进行过滤,如果返回的对象数很多,或者未来会变得很多,那最好采用这种方式

  • 设置为 dynamic 的话,role.users 返回查询对象,并没有做真正的查询,可以利用查询对象做其他逻辑,比如:先排序再返回结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask 配置数据库需要进行以下步骤: 1. 安装数据库驱动:根据你选择的数据库类型,安装相应的数据库驱动。例如,如果你使用的是 SQLite 数据库,可以通过运行以下命令安装驱动: ``` pip install sqlite3 ``` 2. 导入相关模块:在 Flask 应用,需要导入相应的模块来操作数据库。例如,如果你使用 SQLite 数据库,可以导入 `sqlite3` 模块: ```python import sqlite3 ``` 3. 配置数据库连接:在 Flask 应用的配置文件,设置数据库连接的相关配置。你可以指定数据库的类型、主机名、端口号、用户名、密码等信息。例如,对于 SQLite 数据库,可以将以下代码添加到 Flask 应用的配置文件(如 `config.py`): ```python DATABASE = '/path/to/database.db' ``` 4. 初始化数据库连接:在 Flask 应用,可以通过在应用初始化时创建数据库连接。你可以使用 Flask 提供的 `before_first_request` 装饰器,确保在第一个请求处理前初始化数据库连接。例如: ```python from flask import Flask app = Flask(__name__) @app.before_first_request def initialize_database(): # 创建数据库连接 g.db = sqlite3.connect(app.config['DATABASE']) # 设置返回字典格式的查询结果 g.db.row_factory = sqlite3.Row @app.route('/') def index(): # 在请求处理函数使用数据库连接 cursor = g.db.execute('SELECT * FROM users') users = cursor.fetchall() # ... ``` 5. 关闭数据库连接:在 Flask 应用结束时,需要关闭数据库连接。你可以使用 Flask 提供的 `teardown_appcontext` 装饰器,在应用上下文销毁时关闭数据库连接。例如: ```python from flask import Flask, g app = Flask(__name__) @app.teardown_appcontext def close_database(error): # 关闭数据库连接 db = g.pop('db', None) if db is not None: db.close() if __name__ == '__main__': app.run() ``` 以上是在 Flask 配置数据库的基本步骤。在实际应用,还可以使用 ORM(对象关系映射)工具,如 SQLAlchemy,来简化数据库操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值