中,知识点:一个请求 在进入到进程后,会从进程 App中生成一个新的app(在线程中的应用上下文,改变其值会改变进程中App的相关值,也就是进程App的指针引用,包括g,),以及生成一个新的请求上下文(...并把此次请求需要的应用上下文和请求上下文通过dict格式传入到 栈中(从而保证每个请求不会混乱)。并且在请求结束后,pop此次的相关上下文。...错误接口代码大致如下: class 响应如下(每次请求,都会向model类的列表属性值添加元素,这样会随着时间的增长导致内存消耗越来越大,最终导致服务崩溃): ?...总结:刚开始以为 在一次请求过程中,无论怎么操作都不会影响到其他请求的执行,当时只考虑了在 请求上下文中不会出现这种问题,但是 应用上下文,是 进程App相关属性或常量的一个引用(相当于指针),任何对应用上下文中的改变...相关连接: https://blog.tonyseek.com/post/the-context-mechanism-of-flask/
添加模型视图(Adding Model Views) 模型视图允许您添加一组专用的管理页面,用于管理数据库中的任何模型。...Attributes) 有关定义的属性的完整列表,请查看BaseModelView()的API文档。...如果模型中的数据太多,无法在列表视图中显示,则可以通过设置以下内容添加只读详细信息视图: can_view_details = True 从列表视图中删除列很容易,只需为列传递列名称列表“不包括...要在这些下拉列表中嵌套相关视图,请使用添加子类别方法: admin.add_sub_category(name="Links", parent_name="Team") 并向菜单添加任意超链接:...对于您的需求确实是特定的并且您很难通过内置的ModelView类来满足它们的情况,Flask Admin使您能够轻松地完全控制并将自己的视图添加到界面中。
关系选项 backref:在关系的另一模型中添加反向引用,用于设置外键名称,在1查多的 primary join:明确指定两个模型之间使用的联结条件 uselist:如果为False,不使用列表,而使用标量值...在准备把数据写入数据库前,要先将数据添加到会话中然后调用 commit() 方法提交会话。 在 Flask-SQLAlchemy 中,查询操作是通过 query 对象操作数据。...3.1 在视图函数中定义模型类 from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name_...Flask使用Blueprint让应用实现模块化,在Flask中,Blueprint具有如下属性: - 一个应用可以具有多个Blueprint - 可以将一个Blueprint注册到任何一个未使用的URL...- 当在应用对象上调用 route 装饰器注册路由时,这个操作将修改对象的url_map路由表 - 然而,蓝图对象根本没有路由表,当我们在蓝图对象上调用route装饰器注册路由时,它只是在内部的一个延迟操作记录列表
name="user") # user_ldd=User(username="ldd",role=admin_role) # 将改动/新建对象添加到数据库会话管理(app_db.session)中:...shell中查看数据库中对象的属性: # print(admin_role.id) # 注意,对数据库的操作,都需要:添加到数据库会话管理,然后在提交才会真正的在数据库中修改 # 查询: # 使用...# 使用过滤器(filter_by())来更加精确的搜索数据库中的数据,如:User.query.filter_by(role=admin_role).all(),表示返回user表中角色为管理员的数据...) 返回一个Paginate对象,它包含指定范围内的结果 # 关系查询(在role表中有相关关系的定义语句): # users=user_role.users # user表中用户角色为user...# 创建迁移仓库之前首先安装Flask-Migrate pip install flask-migrate # 导入 from flask_migrate import Migrate # 创建对象实列
使用Flask-SQLAlchemy管理数据库 在Flask-SQLAlchemy中,数据库使用URL指定,而且程序使用的数据库必须保存到Flask配置对象的SQLALCHEMY_DATABASE_URI...如果为True,允许有空值,如果为False,不允许有空值 default 为这列定义默认值 常用的SQLAlchemy关系选项 选项名 说明 backref 在关系的另一模型中添加反向引用 primary...join 明确指定两个模型之间使用的联结条件 uselist 如果为False,不使用列表,而使用标量值 order_by 指定关系中记录的排序方式 secondary 指定多对多中记录的排序方式 secondary...在准备把数据写入数据库前,要先将数据添加到会话中然后调用 commit() 方法提交会话。 在Flask-SQLAlchemy中,查询操作是通过query对象操作数据。...示例 2.1 在视图函数中定义模型类 from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name
程序中路由一般是通过程序实例的装饰器实现 Flask调用视图函数后,可以返回2种内容: 字符串:将视图函数的返回值作为响应内容,返回给客户端 HTML模板内容:获得数据后,将数据传入HTML模板中,模板引擎...() 返回一个Paginate对象,它包含指定范围内的结果 查询过滤器 过滤器 说明 filter(对象.属性==值) 把过滤器添加到原查询上,返回一个新查询。...对关系之间提供的一种便利的调用方式,关联不同的表 第1个参数:对象模型名。...指需要关联的对象,可在Role类的实例中通过role.users查看该实例在User模型中的属性 backref参数:对关系提供反向引用的声明。...可在User类的实例中通过user.role查看该实例在Role模型中的属性 class Role(db.Model): __tablename__ = 'roles' id = db.Column
在 orm 中,模型一般是一个 Python 类,类的属性对应数据库表的类。...选项名 说明 backref 在关系的另一模型中添加反向引用 primary join 明确指定两个模型之间使用的联结条件,只在模凌两可的关系中需要制定 uselist 如果为False,不使用列表,而使用标量值...: 添加到Role模型中的users属性代表这个关系的面相对象视角。...对于一个Role类的实例,其users属性将返回与角色相关联的用户组成的列表。 db.relationship() 第一个参数表示这个关系的另一端所指模型,如果模型尚未定义,可以用字符串指定。...这一属性可以替代role_id访问Role模型,此时获取的是模型对象,而不是外键的值。 除了一对多以外,还有其他关系类型。 、 、 。
2.2数据库ORM支持(对应Flask中的FlaskSQLAlchemy) ORM是对象关系映射,就是将数据库的操作都转化成对类,属性和方法的操作,不用写sql语句了,不用关注你使用的是mysql还是Oracle...中request请求对象的属性 Django中request请求对象的属性 说明 args GET 查询字符串参数 form POST 请求体中的表单数据 data body 请求体中的原始bytes数据...,将针对函数视图装饰器,添加到类视图的方法上面。...无论是字典、列表或者元组的元素,都需要使用 .取值,下标或者键名,不能使用 [],这是和Flask有区别的地方。...使用 1.在配置文件中设置配置项MEDIA_ROOT='上传文件的保存目录' 2.定义模型类时,图片字段的类型使用 ImageField 3.迁移生成表并在admin.py注册模型类,直接登录Admin
,比如模型与模型之间的一种关联,根据角色查询属于这个角色的用户有哪些 # 这里的设计不像外键是根据表的实际情况考虑,而根据模型考虑的 # User 是让role对象可以获得user中的属性...,他们是类db.Column的实例,id和username,db.Column 类构造函数的第一个参数是数据库列和模型属性的类型,下面列出了一些常见的列类型以及在模型中使用的Python类型。...添加到address模型中person_id列被定义为外键,就是这个外键建立起了联系。传给db.ForeignKey()的参数’person_id’表明,这一列的值是person表中行的id值。...添加到person表中的address属性代表这个关系的面向对象视角。对于一个person实例,其address属性将返回与person相关联的多个地址。...而且,db.backref()不指定这两个关系之间的引用关系,而是回引Follow模型。 回引中的 lazy 参数指定为 joined 。这个 lazy 模式可以实现立即从联结查询中加载相关对象。
一 数据库的设置 Web应用中普遍使用的是关系模型的数据库,关系型数据库把所有的数据都存储在表中,表用来给应用的实体建模,表的列数是固定的,行数是可变的。它使用结构化的查询语言。...关系型数据库的列定义了表中表示的实体的数据属性。比如:商品表里有name、price、number等。 Flask本身不限定数据库的选择,你可以选择SQL或NOSQL的任何一种。...,不允许有空值 default 为这列定义默认值 常用的SQLAlchemy关系选项 选项名 说明 backref 在关系的另一模型中添加反向引用 primary join 明确指定两个模型之间使用的联结条件...中无法自行决定时,指定多对多关系中的二级联结条件 二 自定义模型类 模型表示程序使用的数据实体,在Flask-SQLAlchemy中,模型一般是Python类,继承自db.Model,db是SQLAlchemy...类中的属性对应数据库表中的列。id为主键,是由Flask-SQLAlchemy管理。db.Column类构造函数的第一个参数是数据库列和模型属性类型。 如下示例:定义了两个模型类,用户和角色。 ?
Model模型、View视图、Template模板) Model模型:操作数据库 View视图:接收请求,进行业务处理、返回响应 Template模板:封装构造要返回的html,展示页面内容 3、MVT...程序创建 1、在定义视图函数的时候,必须接收request(作为形参接收请求对象) Flask框架中的视图函数可以直接返回字符串,但是Django视图返回的必须是响应对象 2、返回响应对象HttpResponse...,相应对象中,传入响应的内容就可以了 3、在子应用下面创建一个文件urls.py,然后创建一个urlpatterns列表,然后再列表里面添加当前子应用中url地址和视图函数的对应关系url("url正则表达式...Flask中:request.form Django中:request.POST 前端发送的表单类型的请求体数据,可以通过request.POST属性获取,返回QueryDict对象。...和Django中request对象属性的对比 ?
Flask 中的数据库框架 每一种语言,都有对应的比较完善的数据库框架,这些框架可以帮助我们更加方便的进行数据库操作,从而屏蔽掉相关的具体 SQL 语句,也可以防止 SQL 注入等安全隐患。...定义模型 模型这个术语表示程序使用的持久化实体。在 ORM 中,模型一般是一个 Python 类,类中的属性对应数据库表中的列。...backref 参数向 User 模型中添加一个 role 属性,从而定义反向关 系。...这一属性可替代 role_id 访问 Role 模型,此时获取的是模型对象,而不是外键的值。 添加到 User 模型中的 role_id 列被定义为外键,就是这个外键建立起了关系。...,我们就留到后面的内容中慢慢学习吧 这部分完整代码,可以检出5a 总结 本节我们学习了数据库相关的内容,从 SQLAlchemy 到 flask_SQLAlchemy,以及如何在视图函数中使用,还有更加方便的迁移数据库等等知识
(object): DEBUG = True # 从配置对象中加载配置 app.config.from_object(Config) # 3.装饰器的作用是将路由映射到视图函数index @...,json对象的属性名称和字符串必须由双引号引起来,否则会报错. json和dict相互转换: # 使用之前需要导入一个类 from flask import json # 1.json转换成字典 dict...7.模板 7.1自定义过滤器 有两种形式,一种是先定义函数,再添加到过滤器列表中,另一种是装饰器的形式.重点掌握第一种. # 先定义一个函数 def do_listreverse(li): # 通过原列表创建一个新列表...,在舍弃一些性能开销的同时,换来的是开发效率的较大提升.是一个关系型数据库的框架,它提供了高层的ORM和底层的原生数据库操作. 8.1.2ORM类 类名称 类属性 类的对象 数据库表名 数据库的字段 数据库表中的一行一行的数据...' 3/将蓝图注册到app中(register_blueprint) app.register_blueprint(admin,url_prefix='/admin') ?
这是类声明: class ModelManager(object): _models = [] ModelManager类有一个名为_models的私有列表属性,它将包含对管理中的模型对象的引用。...所述get_models()方法返回与有关模型对象信息的字典的列表。所述get_model_metadata()方法返回关于单个模型对象的详细数据,与模型对象的qualified_name属性标识。...在_models类属性中搜索模型对象列表时,模型的限定名称用于标识模型。 使用ModelManager类,现在可以使用iris_model包测试它。...Flask视图 Flask框架还能够使用Jinja模板呈现网页,这里可以找到了解这一点的好指南。要将使用Jinja模板呈现的网页添加到Web应用程序,将templates文件夹添加到应用程序包中。...接下来,使用singleton的get_models()方法获取可用模型列表。最后将返回的模型列表发送到模板进行渲染,并将生成的网页返回给用户。此视图还呈现指向模型的元数据和预测视图的链接。
本文将对Flask以及一些基本的使用进行了简单的介绍,方便大家快速理解项目中的相关内容。...python Hello.py 上述代码中,Flask将(name)作为参数,即Flask在当前模块运行,route()函数是一个装饰器,将请求的url映射到对应的函数上。...2.2.1 请求对象 request 在Flask包中,可以直接引入request对象,其中包含Form,args ,Cookies ,files 等属性。...类和数据库表进行关联映射,并通过 _tablename_ 属性将数据库模型类和表进行管理。...其中Column() 表示数据表中的列,Integer()和String()表示数据库的数据类型。
views.py 文件用于编写Web应用视图。 注册安装子应用 注册安装一个子应用的方法,即是将子应用的配置信息文件apps.py中的Config类添加到INSTALLED_APPS列表中。...2、视图函数的返回值必须为一个响应对象,不能像Flask一样直接返回一个字符串,可以将要返回的字符串数据放到一个HTTPResponse对象中。...编辑 1、调整列表页展示 页大小:list_per_page = 100 操作选项的位置: actions_on_top = True actions_on_bottom = True 列表中的列...:list_display = [模型字段1,模型字段2] 将方法作为列:short_description属性 # models.py中: class BookInfo(models.Model)...list_display = ['id','btitle','pub_date'] # 说明: 方法列是不能排序的,需要排序: admin_order_field = 模型类字段 关联对象
我们在使用Flask框架,是从写单个文件,执行hello world开始的。我们在这单个文件中可以定义路由、视图函数、定义模型等等。...3.解决这个互斥问题,可以使用首先避免app.py立即导入admin.py的视图函数的情况,例如将导入admin.py的步骤写到创建app实例之后,如下: ?...注册路由就是一种操作,当在程序实例上调用route装饰器注册路由时,这个操作将修改对象的url_map路由映射列表。...当我们在蓝图对象上调用route装饰器注册路由时,它只是在内部的一个延迟操作记录列表defered_functions中添加了一个项。...当执行应用对象的 register_blueprint() 方法时,应用对象从蓝图对象的 defered_functions 列表中取出每一项,即调用应用对象的 add_url_rule() 方法,这将会修改程序实例的路由映射列表
定义模型 模型是表示应用使用的持久化实体,在ORM中,模型一般是一个Python类,类中的属性就是数据库表中的列。...role_id = db.Column(db.Integer, db.ForeignKey('role_id')) 添加到user模型中的role_id列被定义成外键,就是这个外键建立起列关系。...传给db.ForeignKey()的参数‘role.id'表明,这列的值是roles表中的相应行的id值。 从“一”那一端可知,添加到Role模型中的users属性代表这个关系的面向对象吃的视角。...对于一个Role实例,其users属性将返回和角色相关联的用户组成的列表(也就是“多“那一端)。 db.relationship()的第一个参数表明这个关系的另一端是哪个模型。...backref参数向User模型中添加一个role属性,从而定义反向关系。通过User实例的这个属性可以获得对应的Role模型对象,而不用再通过role_id外键获取。
它使用结构化的查询语言。关系型数据库的列定义了表中表示的实体的数据属性。比如:商品表里有name、price、number等。...数据库连接通过URL指定,而且程序使用的数据库必须保存到Flask配置对象的SQLALCHEMY_DATABASE_URI键中。...backref 在关系的另一模型中添加反向引用 primary join 明确指定两个模型之间使用的联结条件 uselist 如果为False,不使用列表,而使用标量值 order_by 指定关系中记录的排序方式...在Flask-SQLAlchemy中,查询操作是通过query对象操作数据。最基本的查询是返回表中所有数据,可以通过过滤器进行更精确的数据库查询。 下面先来创建两个表的数据模型:用户表和角色表。...在视图函数中定义模型类 看完了上面那么多的概念说明,下面来看看如何创建数据模型以及创建数据表,如下: 1.在脚本15_SQLAlchemy.py编写创建User和Role数据模型 from flask
Flask系列文章: 小白学Flask第一天 | 我的第一个Flask程序 小白学Flask第二天| app对象的初始化和配置 小白学Flask第三天| 今天把视图函数的路由给讲清楚!...我们学习Flask框架,是从写单个文件,执行hello world开始的。我们在这单个文件中可以定义路由、视图函数、定义模型等等。...蓝图是怎么运行的? 蓝图是保存了一组将来可以在应用对象上执行的操作。 注册路由就是一种操作,当在程序实例上调用route装饰器注册路由时,这个操作将修改对象的url_map路由映射列表。...当我们在蓝图对象上调用route装饰器注册路由时,它只是在内部的一个延迟操作记录列表defered_functions中添加了一个项。...当执行应用对象的 register_blueprint() 方法时,应用对象从蓝图对象的 defered_functions 列表中取出每一项,即调用应用对象的 add_url_rule() 方法,这将会修改程序实例的路由映射列表
领取专属 10元无门槛券
手把手带您无忧上云