数据模型

模型关系

  • 一对多(使用最多)

    • 一:学生(Student)

      • 需要添加反向引用
    • 多:文章(Article)
      • 需要添加外键关联
  • 一对一
    • 一:学生(Student),主表

      • 需要添加反向引用,在一对多的情况下多指定属性userlist=False即可
    • 一:详情(Profile),次表
      • 需要添加外键关联
  • 多对多
    • 多:学生(Student)

      • 需要添加反向引用
      • 添加反向引用时需要通过secondary指定中间关联表
      • 设置反向引用的查询时机,可以通过db.backref完成
    • 多:课程(Course)
    • 中间关联表:学生选课表,不需要进行操作和维护
      • 字段:表名、外键关联

模型总结

  • 等价查询

    @app.route('/query/')
    def query():
    # students = Student.query.all()
    # 等价于
    students = db.session.query(Student).all()
    return ','.join(s.name for s in students)
  • 指定字段查询

    @app.route('/select/')
    def select():
    # ret = db.session.query(Student.id, Student.name).all()
    # 指定字段查询,等价于上式
    ret = Student.query.with_entities(Student.id, Student.name).all()
    # 返回指定字段组成的元组构成的列表
    print(ret)
    return '查询结束'
  • 分页查询:paginate,项目中讲解。

  • 查看SQL日志:就是查看执行过的SQL语句。

    # 记录SQL日志,需要满足以下三个条件中的任意一个即可
    # app.config['DEBUG'] = True
    # app.config['TESTING'] = True
    app.config['SQLALCHEMY_RECORD_QUERIES'] = True from flask_sqlalchemy import get_debug_queries queries = get_debug_queries()
    for q in queries:
    print(q)

数据缓存

  • 说明:

    数据库的速度是一个web应用的性能瓶颈,因此,为了提高访问效率,应该尽可能减少数据库的访问。可以将经常访问的数据缓存起来,每次访问时先从缓存中获取数据,若有直接返回;没有再从数据库中读取。

  • flask-cache:专门负责数据缓存的扩展。

  • 安装:pip install flask-cache

  • 使用:

    from flask_cache import Cache
    
    # 配置
    # 缓存类型
    app.config['CACHE_TYPE'] = 'redis'
    # 主机
    app.config['CACHE_REDIS_HOST'] = '127.0.0.1'
    # 端口
    app.config['CACHE_REDIS_PORT'] = 6379
    # 数据库
    app.config['CACHE_REDIS_DB'] = 1 # 创建对象
    cache = Cache(app, with_jinja2_ext=False)
  • 缓存视图函数:

    @app.route('/')
    # timeout:指定缓存有效期,默认300s
    # key_prefix:缓存键前缀,默认:view/ + 路由地址
    @cache.cached(timeout=100, key_prefix='index')
    def index():
    print('读取数据库')
    return '有效数据'
  • 缓存普通函数:

    # 缓存普通函数,key_prefix必须指定
    @cache.cached(timeout=100, key_prefix='common')
    def common():
    print('查询数据库')
    return '返回的数据' @app.route('/hello/')
    def hello():
    return common()
  • 清除缓存

    @app.route('/clear/')
    def clear():
    # 指定删除
    # cache.delete('index')
    # 全部清空
    cache.clear()
    return '缓存已清除'
  • 自定义缓存

    @app.route('/zidingyi/')
    def zidingyi():
    # 先从缓存中获取
    data = cache.get('zidingyi_data')
    if data:
    return data
    # 没有缓存数据
    print('从数据库中获取数据')
    data = '123456'
    # 缓存数据
    cache.set('zidingyi_data', data, timeout=100)
    return data

Flask—06-理解掌握flask数据模型(02)的更多相关文章

  1. Flask 框架理解(一)

    Flask 框架理解(一) web 服务器 , web 框架 以及 WSGI 这里说的 web 服务器特指纯粹的 python HTTP 服务器(比如 Gunicorn,而不是 Apache,Ngin ...

  2. python 全栈开发,Day142(flask标准目录结构, flask使用SQLAlchemy,flask离线脚本,flask多app应用,flask-script,flask-migrate,pipreqs)

    昨日内容回顾 1. 简述flask上下文管理 - threading.local - 偏函数 - 栈 2. 原生SQL和ORM有什么优缺点? 开发效率: ORM > 原生SQL 执行效率: 原生 ...

  3. Flask最强攻略 - 跟DragonFire学Flask - 第六篇 Flask 中内置的 Session

    Flask中的Session非常的奇怪,他会将你的SessionID存放在客户端的Cookie中,使用起来也非常的奇怪 1. Flask 中 session 是需要 secret_key 的 from ...

  4. Flask最强攻略 - 跟DragonFire学Flask - 第四篇 Flask 中的模板语言 Jinja2 及 render_template 的深度用法

    是时候开始写个前端了,Flask中默认的模板语言是Jinja2 现在我们来一步一步的学习一下 Jinja2 捎带手把 render_template 中留下的疑问解决一下 首先我们要在后端定义几个字符 ...

  5. 使用Flask+uwsgi+Nginx部署Flask正式环境

    环境准备 在开始正式讲解之前,我们将首先进行环境准备. Step1:安装Python,pip以及nginx: sudo apt-get update sudo apt-get install pyth ...

  6. Flask 入门一( flask 框架和 flask-script 库)

    Flask 入门一( flask 框架 和 flask-script 库) 一.Flask框架: 1.简介 Flask是一个非常小的Python Web框架,被称为微型框架:只提供了一个稳健的核心,其 ...

  7. 初识Flask框架,以及Flask中的模板语言jinjia2和Flask内置的Session

    一.web框架的对比 首先我们先来看下比较火的web框架 1.Django: 优点:大而全,所有组件都是组织内部开发高度定制化,教科书级别的框架 缺点:大到浪费资源,请求的时候需要的资源较高 2.Fl ...

  8. Flask(3)- flask中的CBV、werkzeug+上下文初步解读、偏函数和线程安全

    一.flask中的CBV 对比django中的CBV,我们来看一下flask中的CBV怎么实现? from flask import Flask, render_template, url_for, ...

  9. 第七篇 Flask实例化配置及Flask对象配置

    一.Flask对象的配置 Flask 是一个非常灵活且短小精干的web框架 , 那么灵活性从什么地方体现呢? 有一个神奇的东西叫 Flask配置 , 这个东西怎么用呢? 它能给我们带来怎么样的方便呢? ...

  10. flask 第六篇 flask内置的session

    Flask中的Session非常的奇怪,他会将你的SessionID存放在客户端的Cookie中,使用起来也非常的奇怪 1. Flask 中 session 是需要 secret_key 的 from ...

随机推荐

  1. 深入理解JavaScript系列(10):JavaScript核心(晋级高手必读篇)

    本篇是ECMA-262-3 in detail系列的一个概述(本人后续会翻译整理这些文章到本系列(第11-19章).每个章节都有一个更详细的内容链接,你可以继续读一下每个章节对应的详细内容链接进行更深 ...

  2. C# 获取字符串长度

    int leng = System.Text.Encoding.Default.GetBytes(attachfileId2).Length;

  3. C#学习笔记9

    1.多播委托:由与delegate关键字声明的委托,在编译后默认继承Delegate与MulticastDelegate类型,所以声明的委托自然就含有多播委托的特性,即一个委托变量可以调用一个方法链( ...

  4. Resharper 的快捷键

      编辑   Ctrl + Space 代码完成 Ctrl + Shift + Space代码完成 Ctrl + Alt + Space代码完成 Ctrl + P 显示参数信息 Alt + Inser ...

  5. Linux 套接字编程 - select

    select 可以感知文件表述符集合中的变化,如果办fd0(即标准输入)放入select的read fd set,发现只有按回车的时候select才会返回.查了下要把终端的缓冲大小设为1,这样就能实现 ...

  6. vue——指令系统

    指令系统,可以联想咱们的cmd命令行工具,只要我输入一条正确的指令,系统就开始干活了. 在vue中,指令系统,设置一些命令之后,来操作我们的数据属性,并展示到我们的DOM上. 在vue中提供了一套为数 ...

  7. html+css动态篇

    transition过渡 transform旋转 animation动画 一般是父div包含两个子div,一个写鼠标悬浮之前,一个写鼠标悬浮之后, 鼠标悬浮之后的div要写overflow:hidde ...

  8. javascript统计一个字符在一段字符串出现次数

      <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8" ...

  9. Avro-RPC client in Flume

    Avro used in Flume Define the interface of RpcClient public interface RpcClient { public int getBatc ...

  10. Android 多个activity之间的共享数据

    最近打算做一个时间助手,一个service监听课表信息.课表信息可以通过另外的activity来设置,所以这里就涉及到了数据的同步问题.我设置后的信息必须同步到监听的信息去. 在java中我们用全局变 ...