Flask学习【第11篇】:整合Flask中的一些知识点
SQLAlchemy-Utils
由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法
import datetime
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String, Text, ForeignKey, DateTime, UniqueConstraint, Index
from sqlalchemy.orm import relationship
from sqlalchemy_utils import ChoiceType Base = declarative_base()
class Xuan(Base):
__tablename__ = 'xuan'
types_choices = (
(1,'欧美'),
(2,'日韩'),
(3,'老男孩'),
)
id = Column(Integer,primary_key=True,autoincrement=True)
name = Column(String(64))
types = Column(ChoiceType(types_choices,Integer())) __table_args__ = {
'mysql_engine':'Innodb',
'mysql_charset':'utf8',
} engine = create_engine(
"mysql+pymysql://root:123@127.0.0.1:3306/ttt2?charset=utf8",
max_overflow=0, # 超过连接池大小外最多创建的连接
pool_size=5, # 连接池大小
pool_timeout=30, # 池中没有线程最多等待的时间,否则报错
pool_recycle=-1 # 多久之后对线程池中的线程进行一次连接的回收(重置)
) Base.metadata.create_all(engine) 查询:
result_list = session.query(Xuan).all()
for item in result_list:
print(item.types.code,item.types.value)
scoped_session
from sqlalchemy.orm import sessionmaker
from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session
engine = create_engine(
"mysql+pymysql://root:123@47.93.4.198:3306/ttt?charset=utf8",
max_overflow=0, # 超过连接池大小外最多创建的连接
pool_size=5, # 连接池大小
pool_timeout=30, # 池中没有线程最多等待的时间,否则报错
pool_recycle=-1 # 多久之后对线程池中的线程进行一次连接的回收(重置)
)
SessionFactory = sessionmaker(bind=engine)
# 方式一:由于无法提供线程共享功能,所有在开发时要注意,在每个线程中自己创建 session。
# from sqlalchemy.orm.session import Session
# 自己具有操作数据库的:'close', 'commit', 'connection', 'delete', 'execute', 'expire',.....
session = SessionFactory() # print('原生session',session)
# 操作
session.close() # 方式二:支持线程安全,为每个线程创建一个session
# - threading.Local
# - 唯一标识
# ScopedSession对象
# self.registry(), 加括号 创建session
# self.registry(), 加括号 创建session
# self.registry(), 加括号 创建session
from greenlet import getcurrent as get_ident
session = scoped_session(SessionFactory,get_ident)
# session.add
# 操作
session.remove()
Flask-SQLAlchemy和Flask-Migrate 组件
4、Flask-SQLAlchemy:吧Flask和SQLAlchemy结合在一起,粘合剂
在__init__.py 文件中
1 引入Flask-SQLAlchemy 中的SQLAlchemy,实例化了一个SQLAlchemy对象
2 注册Flask-SQLAlchemy:
- 有两种方式
方式一: 在函数里面,SQLAlchemy(app) #如果想在其他地方使用这种方式就不好使了
方式二: 在全局:
db = SQLAlchemy(),
在函数里面 db.init_app(app) #调用init_app方法吧app放进去了
3、导入models的类
4、导入的类中继承了db.model,其实本质上还是继承了Base类
5、manage.py 创建数据库表,可以通过命令来创建。借助Flask-Migrate组件来完成
5、Flask-Migrate:
-旧5 被毙掉了:在manage.py里面导入db,以后执行db.create_all()创建表,以后执行drop_all()删除表
这样不好,我们可以和Flask-Migrate结合起来用
-新5:Flask-Migrate
- 安装组件:pip install Flask-Migrate
- 5.1 导入
from flask_migrate import Migrate, MigrateCommand
from app import db, app
- 5.2 migrate = Migrate(app,db) #创建实例
- 5.3 创建命令
manager.add_command("db",MigrateCommand)
- 5.4 执行命令
python manage.py db init #只执行第一次
python manage.py db migrate
python manage.py db upgrade
在执行命令之前,得先连接数据库,他才会知道吧表放在那里,
详说注册SQLAlchemy的两种方式
方式一
from flask_sqlalchemy import SQLAlchemy
from flask import FLask
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = \
"mysql://root:12345@localhost/test"
db = SQLAlchemy(app)
方式二
from flask_sqlalchemy import SQLAlchemy
from flask import FLask
db = SQLAlchemy() def create_app():
app = Flask(__name__)
db.init_app(app)
return app
操作数据库
通过上面注册了SQLAlchemy,就直接可以从db.session了
#方式一
db.session #会自动创建一个session
db.session.add()
db.session.query(models.User.id,models.User.name).all()
db.session.commit()
db.session.remove()
#方式二
导入models
models.User.query
Flask中所有用到过的组件
所有用过的组件
Flask
连接数据库的两种操作
要么DBUtils:用于执行原生SQL的
用自己的util里面的sqlhelper来完成
要么SQLAlchemy:遵循他自己的语法来链接
方式一:SQLAlchemy(app)这种方式有局限性,如果我在其他地方也得用到呢?可以吧它写到全局
方式二:优点,
实例化一下:db = SQLAlchemy()
注册:
在settings里面配置一下数据库链接方式
SQLALCHEMY_DATABASE_URI = "mysql+pymysql://root:123@47.93.4.198:3306/s6?charset=utf8"
SQLALCHEMY_POOL_SIZE = 2
SQLALCHEMY_POOL_TIMEOUT = 30
SQLALCHEMY_POOL_RECYCLE = -1
Flask-SQLAlchemy: db.init_app(app) Flask-Session #用于吧session保存在其他地方
Flask-Script #生成命令
Flask-Migrate #数据库迁移
Flask-SQLAlchemy #将Flask和SQLAlchemy很好的结合在一起
#本质、:每次操作数据库就会自动创建一个session连接,完了自动关闭
Blinker #信号
Wtforms #FORM组件
用到的组件和版本
pip3 freeze #获取环境中所有安装的模块
pip3 freeze > a.txt
pip3 freeze > requirements.txt
#pip3 install pipreqs #帮你找到当前程序的所有模块,并且自动生成 requirements.txt文件,写入内容
pipreqs ./ #根目录 以后别人给你一个程序,告知你一个文件夹需要安装的组件:requirements.txt
进入程序目录:
pip install -r requirements.txt #就会把设计到的所有的组件就会装上 结构:
app
static
templates
views
__init__.py
models.py
Flask学习【第11篇】:整合Flask中的一些知识点的更多相关文章
- Flask【第11篇】:整合Flask中的目录结构
整合Flask中的目录结构 一.SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import ...
- Flask系列(十一)整合Flask中的目录结构(sqlalchemy-utils)
一.SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import datetime from ...
- Egret入门学习日记 --- 第九篇(书中 2.7~2.8节 内容)
第九篇(书中 2.7~2.8节 内容) 昨天记录到了 2.6节 ,那么今天就从 2.7节 开始. 这个 2.7节 有7个小段,有点长,总结一下重点: 1.调试项目的两种方法. 2.运行项目的两种窗口选 ...
- Flask学习之旅--用 Python + Flask 制作一个简单的验证码系统
一.写在前面 现在无论大大小小的网站,基本上都会使用验证码,登录的时候要验证,下载的时候要验证,而使用的验证码也从那些简简单单的字符图形验证码“进化”成了需要进行图文识别的验证码.需要拖动滑块的滑动验 ...
- TMS320DM642学习----第六篇(CCS中.dat文件类型详解)
1.如下为.dat文件中文件头的基本格式: MagicNumber Format StartingAddress PageNum Length [NewFormat] 下面是分别的解释: MagicN ...
- Dubbo学习笔记11:使用Dubbo中需要注意的一些事情
指定方法异步调用 前面我们讲解了通过设置ReferenceConfig的setAsync()方法来让整个接口里的所有方法变为异步调用,那么如何指定某些方法为异步调用呢?下面讲解下如何正确地设置默写方法 ...
- spring 5.x 系列第11篇 —— 整合memcached (xml配置方式)
文章目录 一.说明 1.1 XMemcached客户端说明 1.2 项目结构说明 1.3 依赖说明 二.spring 整合 memcached 2.1 单机配置 2.2 集群配置 2.3 存储基本类型 ...
- sqlite学习笔记11:C语言中使用sqlite之删除记录
最后一节,这里记录下怎样删除数据. 前面全部的代码都继承在这里了,在Ubuntu14.04和Mac10.9上亲測通过. #include <stdio.h> #include <st ...
- salesforce零基础学习(九十六)项目中的零碎知识点小总结(四)
本篇参考: https://developer.salesforce.com/docs/atlas.en-us.216.0.apexcode.meta/apexcode/apex_classes_ke ...
随机推荐
- js执行上下文
js在执行是会有一个“准备工作”: 主要内容有 1.变量.函数表达式——>变量声明,默认赋值为undefined: 2.this——>赋值: 3.函数声明——>赋值: 这三种数据的准 ...
- 参考termux中包管理命令的伪装修改的arch版包管理命令
#!/bin/bash set -e -u show_help() { echo "This help message is useless, please read the content ...
- NetSpeed
NetSpeed公司提供的NOC包括三部分,可以通过NocStudio进行配置生成. 1)NetSpeed Orion,面向快速SoC design的可综合平台. 2)Linley NetSpeed ...
- kali linux dns劫持
1,確定局域網ip 2,修改/etc/ettercap/etter.dns 添加自己的ip和劫持域名 3,/var/www/index.html (修改html页面替换被劫持的 ...
- url中是否加斜杠/
通常来说,不加斜杠的形式(如”example.jsp”)请求的是相对于当前页面路径的资源 http://localhost:8080/webapp/examole:加斜杠的形式(”/example.j ...
- Java多线程-----原子变量和CAS算法
原子变量 原子变量保证了该变量的所有操作都是原子的,不会因为多线程的同时访问而导致脏数据的读取问题 Java给我们提供了以下几种原子类型: AtomicInteger和Ato ...
- HashSet, HashTable
HashTable 存储键值对 , Hashtable和Dictionary<TKey,TValue>都是存键值对 HashSet 只存储值,盛放不同的数据,相同的数据只保留一份 Hash ...
- JavaScript <script>标签的位置、延迟脚本(defer属性)与 异步脚本(async属性)
一.<script>标签的位置 传统的做法是将<script>元素放在<head>元素中,例如: <!DOCTYPE html><html > ...
- JAVA基础3---JVM内存模型
Java虚拟机执行Java程序的时候需要使用一定的内存,根据不同的使用场景划分不同的内存区域.有公用的区域随着Java程序的启动而创建:有线程私有的区域依赖线程的启动而创建 JVM内存模型大致可以分为 ...
- Linux基础命令---文本过滤coi
col 过滤掉影响阅读的控制字符,使用重定向符把说明手册的内容输出到文本文件时,控制字符就成乱码.col指令可以过滤掉控制字符,使文本可读.col从标砖输入读取内容,输出到标准输出.col在读取字符时 ...