===sqlalchemy创建的数据模型中:
1 字段是属性   【模型中定义的字段是类属性,表单中定义的字段也是类字段】

2 若数据库不支持bool类型,则sqlalchemy会自动将bool转成0和1

3 若不显示指明表名,则表名为模型名的小写

4 sqlalchemy默认的__init__会将定义的类属性作为__init__的关键字参数

===查询语句:User是名,不是实例名

1 User.query.all()

2 User.query.limit(10).all()

3 User.query.order_by(User.age).all()

3 User.query.order_by(User.age.desc()).all()

3 User.query.first()

3 通过主键获取一行数据:User.query.get()

3 过滤:filter 和filter_by,但filter_by只能查找确切值:User.query.filter_by(username='haha').all()    User.query.filter(User.username='haha').all()

filter 还支持 in_ or_ not_

db.session.query(func.count(Gift.id), Gift.isbn).filter(
Gift.launched == False,
Gift.isbn.in_(isbn_list),
Gift.status == 1).group_by(
Gift.isbn).all()

3 add、delete和update都要commit,查询不需要

delete 要先查询出再删

user = User.query.first()

db.session.delete(user)

db.session.commit()

增加记录:

user = User()
db.session.add(user)
db.session.commit()

===模型关系

一对多时,外键在多的那一方

uid = Column(Integer, ForeignKey('user.id'), nullable=False) #user是表名,id是表中的字段

综上,ForeignKey里的是表名,relationship里的是类名

=====db.session.commit帮我们实现了事务

======Jinja模板中的变量可以是任意python对象,只要他能被python的str()方法转换成一个字符串

=======

{%if   %}  if里可以有过滤器

{% else %}

{% endif %}

======

{%for   a in b %}   循环内有个特殊 变量 loop,获取循环的一些信息,如迭代次数

{% endfor %}

=====for 和 if 嵌套

====

若url_for中的url带参数,可以通过关键字参数的形式传入url_for:url_for('web.book_detail', isbn=current_gift.isbn)

==============

jinja对Flask提供的特有支持:request、config、session、url_for 、get_flashed_messages()、g

=========Bootstrap是一些列CSS样式的集合

get_or_404  first_or_404

============

字段检查器都可以接受一个message参数,表示检测没通过时返回的信息

==========从flask_wtf中import的form才有validate_on_submit这个方法,从wtforms引入的form没有此方法

form.validate_on_submit() 会1)判断请求是否为post请求2)字段是否通过校验

===========

g对象保存每个特定请求的临时数据,是线程安全的,请求结束时,这个对象就销毁了

==========

通常abort和errorhandler一起用,abort返回一个http错误码,errorhandler处理这个错误码

errorhandler可以接收多个错误码

=========类视图函数的定义  MethodView

======

from flask_restful import reqparse
self.paser = reqparse.RequestParser() #参数解析器
self.paser.add_argument('wfids',required=True,location=['args','headers']) #从URL参数中或HTTP请求头中找出wfids变量
args = self.paser.parse_args()  #获取参数的解析结果
=========
在return语句中,若返回的是一个元组,第2个内容作为http状态码,还可以用字典作为第3个参数,表示响应头内容
=========

通过curl发送get请求:curl http://localhost:5000/api/post/1
发送post请求:curl -d "title=HAHA" -d "tag=python" http://localhost:5000/api/post

curl中使用-X来创建put请求 curl -X PUT -d "tile=haha" -d "token=***" http://localhost:5000/api/post/110

=========

对于api,为了进行身份认证,可以使用token,token通常都设过期时间,这样即使token被窃取了也只能用一段时间

from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
def generate_token(self, expiration=): #生成token
s = Serializer(secret_key=current_app.config['SECRET_KEY'], expires_in=expiration)
return s.dumps({'id': self.id}).decode('utf-8')
#######解析token
def parse_token(token):
s = Serializer(secret_key=current_app.config['SECRET_KEY'])
try:
data = s.loads(token.encode('utf-8'))
except:
return False uid = data.get('id')

=========

sql 优势:支持事务(持久性、隔离性、原子性、一致性)
劣势:慢(postgre其实也不慢)、可扩展性差(不能把数据拆分到多个库,如A-H的存入一个库,I-P的存入一个库,因为join需要获取整张表的数据)

nosql:劣势:不支持事务
优势:快(不用调优就很快)、可扩展、无固定表结构

BJSON是二进制json,允许把json存为二级制格式,而不是字符串,这样能节省大量空间

=================

深入理解flask 笔记的更多相关文章

  1. flask笔记(三)Flask 添加登陆验证装饰器报错,及解析

    Flask 添加登陆验证装饰器报错,及解析 写这个之前,是想到一个需求,这个是关于之前写Flask笔记(二)中的一个知识点,路由相关 需求为 : 有一些页面必须是登陆之后才能访问的,比如Shoppin ...

  2. Flask笔记1

    Flask笔记 首先明确一下,要运行一个动态网页,我们需要 一个 Web 服务器来监听并响应请求,如果请求的是静态文件它就直接将其返回,如果是动态 url 它就将请求转交给 Web 应用. 一个 We ...

  3. 19.fastDFS集群理解+搭建笔记

    软件架构理解 1FastDFS介绍 1.1什么是FastDFS FastDFS是用c语言编写的一款开源的分布式文件系统.FastDFS为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并 ...

  4. flask笔记一

    最近学习flask,由于web开发方面接触的并不是很多,所以看官方文档有点焦头烂额,好多的概念不理解. <Flask web 开发>比较基础,先用这本书做个入门. 1.Flask实例化对象 ...

  5. Flask笔记:RESTful

    RESTful是用于前台和后端进行通信的一种规范或者说一种风格,采用的是HTTP和HTTPS协议,数据传输的格式使用的都是JSON,而不是XML.通常,RESTful的URL中只有名词,没有动词,而且 ...

  6. Flask笔记:信号机制

    Flask中有内置的一些信号,也可以通过三方库blinker自定义信号,其实Flask内置的信号也是优先使用的blinker库,如果没有安装blinker才会使用自定义的信号机制.可以通过点击任意导入 ...

  7. Flask笔记:session

    session与cookie: cookie是一项浏览器的技术,而不是服务器的技术,服务器端是无法直接操作cookie的,只能通过返回Response响应告诉浏览器怎么操作cookie.而sessio ...

  8. Flask笔记(一)

    first_flask_project.py # 从flask这个包中导入Flask这个类 # Flask这个类是项目的核心,以后很多操作都是基于这个类的对象 # 注册url.注册蓝图等都是基于这个类 ...

  9. flask笔记3-模板

    flask框架使用jinja2模板引擎.简单的说,模板就是一个纯html文件中夹杂着占位符,在渲染模板时用真实变量值替换占位符,就形成了最终的前台页面. 1.模板存放位置: 默认情况下,flask在根 ...

随机推荐

  1. was8.5调用HttpPost使用httpClient-4.5.1.jar与was原生自带jar包冲突

    一.更换jar方法. 1.将httpClient4.5.1.jar包去掉,更换使用commons-httpclient-3.1.jar. 2.更换方法,将HttpPost类转换为PostMethod类 ...

  2. [十一集训] Day1 (2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018))

    A Altruistic Amphibians 原题 题目大意: n只青蛙在高度为d的井中,每只有跳跃距离.重量和高度,每只青蛙可以借助跳到别的青蛙的背上而跳出井,每只青蛙能承受的最大重量是自身重量, ...

  3. Magic Line(思维+计算几何问题)(2019牛客暑期多校训练营(第三场))

    示例: 输入: 140 1-1 01 00 -1 输出:-1 999000000 1 -999000001 题意:给定平面上一系列的点,求一条以(x1,y1),(x2,y2)两点表示的直线将平面分为包 ...

  4. python之生成器yeild

    python生成器Generator——yield 思考: 首先思考这样一个问题: 创建一个列表,但是内存受限,容量一定是有限的.那么如果创建了一个包含100万个元素的列表,不仅占用很大的存储空间,而 ...

  5. ByteArray、16进制、字符串之间的转换

    ByteArray.16进制.字符串之间的转换: package fengzi.convert { import flash.utils.ByteArray; public class ByteArr ...

  6. 关闭 禁止 window10 UpdateOrchestrator UsoSvc服务

    背景故事:w10流氓更新关了! 然后重启还更新? 读者肯定关过win10自动跟新服务 如图: 然后 还有这个流氓设置 然而微软还有一招啊! 前有win10 update 后有计划任务 powershe ...

  7. 使用CertUtil.exe下载远程文件

    使用CertUtil.exe下载远程文件 证书 https://www.cnblogs.com/17bdw/p/8728656.html 1.前言 经过国外文章信息,CertUtil.exe下载恶意软 ...

  8. Linux定时清理日志脚本

    在应用疯狂打日志的情况下,服务器很容易被塞满磁盘. 先要写一个shell脚本,脚本如下. #!/bin/bash #----------------使用规范---------------- #1.该文 ...

  9. JavaScript,数组,方法;

    JavaScript,数组除了常见的增删查改,其他的方法也有很多. let arr = [1, 3, 7, 6, 9, 4, 6, 2]; 1:every方法, 对数组进行遍历,每个元素都满足条件时, ...

  10. 【译】Python数据结构

    本章将更详细地描述您已经学到的一些内容,并添加了一些新的内容. 5.1 关于列表的更多内容 列表数据类型有一些更多的方法. 以下是列表对象的所有方法: list.append(x) 将项目添加到列表的 ...