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 ...
随机推荐
- leetCodelinked-list-cycle-ii找到链表的环
题目 Given a linked list, return the node where the cycle begins. If there is no cycle, return null. N ...
- 1.sklearn库的安装
sklearn库 sklearn是scikit-learn的简称,是一个基于Python的第三方模块.sklearn库集成了一些常用的机器学习方法,在进行机器学习任务时,并不需要实现算法,只需要简单的 ...
- D. Duff in Beach
题意 数字串a[0---n-1], 通过不断的重复组成了 b[0,---l-1]l<10^18, 让你计算出 长度小于等于k的最长非递减子序列,满足,取得第 i 个取得是 L1 第i+1个取得 ...
- Block 循环引用(上)
iOS的内存管理机制 Objective-C在iOS中不支持GC(垃圾回收)机制,而是采用的引用计数的方式管理内存. 引用计数:在引用计数中,每一个对象负责维护对象所有引用的计数值.当一个新的引用指向 ...
- Ontology Relations
Overview The following page documents the relations used in the filtered GO ontology. For informatio ...
- 【转】Kylin系列-使用Saiku+Kylin构建多维分析OLAP平台
关于Kylin的介绍和使用请参考之前的文章 <分布式大数据多维分析(OLAP)引擎Apache Kylin安装配置及使用示例> Kylin对外提供的是SQL查询接口,基于Kylin构建OL ...
- 抓取https网页时,报错sun.security.validator.ValidatorException: PKIX path building failed 解决办法
抓取https网页时,报错sun.security.validator.ValidatorException: PKIX path building failed 解决办法 原因是https证书问题, ...
- 设置 DNS,防止 DNS 污染,清除 DNS 缓存ipconfig /flushdns
设置 DNS,防止 DNS 污染选中“使用下面的 DNS 服务器地址”,“首选 DNS 服务器”中填写 8.8.8.8,“备用 DNS 服务器”中填写 8.8.4.4,然后点击“确定”按钮清除 DNS ...
- vue 加载更多
<template> <div> <ul> <li v-for="item in articles"> ...
- Could not complete request
Could not complete request com.alibaba.dubbo.rpc.RpcException: Forbid consumer 10.254.1.26 access se ...