1,flask-migrate介绍:

  因为采用db.create_all()在后期修改字段的时候不会自动的映射到数据库中,必须删去表,然后运行,所以我们用flask-migrate来映射。

db.create_all()才会重新映射,这样不符合我们的需求,因此flask-migrate就是为了解决这个问题,他可以在
每次修改模型后,可以将修改的东西映射到数据库中。

2,如下图,当用户请求服务器时,那flask服务器会将当前app推入app栈中,所以当用“db.init_app(app)”的“db”的变量(这个db可以初始化很多app,所以得具体指定出当前app,这时候需要入栈),他就会从栈里去取栈顶的元素,拿到之后再给他初始化。当没有用户访问服务器时,相当于没执行视图函数,即app没放在app栈中,这时候读取的就是空的东西,
“with app.app_context():

db.create_all()”相当于手动入栈的过程。

结果对比:

那么这和我们的迁移有什么关系呢?

请看下面的问题:

我想在下面的模型里加一个字段telephone:

from exts import db

class Author(db.Model):
__tablename__ = "author"
id = db.Column(db.Integer,primary_key=True,autoincrement=True)
name = db.Column(db.String(),nullable=False)

那么我直接在下面加再运行代码会出问题,因为已经生成的数据模型不能再更改,所以这里需要用到数据迁移:

在model中添加telephone后在迁移并映射后变为:

代码:

app.py
from flask import Flask
from models import Author
from exts import db
import config app = Flask(__name__)
app.config.from_object(config)
db.init_app(app) # db.create_all() # with app.app_context():
# db.create_all()
# migrate步骤2:
# 当manage.py/“migrate步骤”中执行后,上面两句就可以不要了。 @app.route('/')
def hello_world():
return 'Hello World!' if __name__ == '__main__':
app.run()
exts.py
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()
models.py
from exts import db class Author(db.Model):
__tablename__ = "author"
id = db.Column(db.Integer,primary_key=True,autoincrement=True)
name = db.Column(db.String(),nullable=False)
# migrate步骤3:
telephone = db.Column(db.String(),nullable=False)

migrate.py
from flask_script import Manager
from app import app
from exts import db
from flask_migrate import Migrate,MigrateCommand
from models import Author # migrate步骤1:
# 模型 --> 迁移 --> 表,分别用下面语句实现
# “python manage.py db init” --> “python manage.py db migrate” --> “python manage.py db upgrade”
# 作用分别是1,初始化一个迁移环境。,做出一个迁移表。,映射成表。 # migrate步骤4:
# “python manage.py db migrate” --> “python manage.py db upgrade” manager = Manager(app) migrate = Migrate(app,db) manager.add_command("db",MigrateCommand) if __name__ == '__main__':
manager.run()
config.py
# encoding:utf-
#dialect+driver://username:password@host:port/database
# dialect:是数据库的实现,比如MySql,SQLlite,且转换为小写
# driver:对应的驱动,比如MySql的驱动是MySqldb
# username:连接数据库的用户名
# password:密码
# host:连接数据库的域名
# port:数据库监听的端口号
# database:是连接的数据库的名字,创建数据库语句为:
"""create database db_demo1(database_name) charset utf8;""" # 如果以上输出了1则说明SQLAlchemy能成功连接到数据库。 DIALECT = "mysql"
DRIVER = "mysqldb"
USERNAME = "root"
PASSWORD = ''
HOST = "127.0.0.1"
PORT = ""
DATABASE = "db3" SQLALCHEMY_DATABASE_URI="{}+{}://{}:{}@{}:{}/{}".format(DIALECT,DRIVER,USERNAME,PASSWORD,HOST,PORT,DATABASE)
"""指定一个名为SQLALCHEMY_DATABASE_URI的固定变量,注意是固定的写法"""
SQLALCHEMY_TRACK_MODIFICATIONS =False

06flask_migrate的更多相关文章

随机推荐

  1. windows7 64位使用anaconda傻瓜式安装tensorflow

    1.下载anaconda并一键安装 登录网页:https://www.anaconda.com/download/ 这里选择Python3.6 version 64-Bit Graphlcal Ins ...

  2. Bootstrap常用样板

    http://blog.csdn.net/Star_449/article/details/76098292 1.图片样式 1.1..img-responsive: 直接为图片添加该样式,可以实现响应 ...

  3. python 学习 leetcode ---number of island

    Given a 2d grid map of '1's (land) and '0's (water), count the number of islands. An island is surro ...

  4. js数组扁平化

    看到一个有趣的题目: var arr = [ [1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14] ] ] ], 10]; 一个多维 ...

  5. 基于Gecko内核的简单浏览器实现

    分享一个基于Gecko内核的简单浏览器实现过程. 项目需要需要开发一个简单浏览器,由于被访问的网页中有大量Apng做的动画,使用IE内核的webbrowser不能播放,使用基于WebKit和Cefsh ...

  6. 2018-2019-2 20165234 《网络对抗技术》 Exp5 MSF基础应用

    实验五 MSF基础应用 实验内容 本实践目标是掌握metasploit的基本应用方式,重点常用的三种攻击方式的思路.具体需要完成: 1.一个主动攻击实践,ms08_067(成功) 2. 一个针对浏览器 ...

  7. json中的json.dumps()

    Json简介 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于JavaScript(Standard ECMA-262 3rd Edition - ...

  8. 生成透视列之for xml path

    临时表#t原始数据: 实现如下格式,即根据Province分组,把每个组对应的City列以某种格式展示: 实现方法: select t.Province,(select city+',' From # ...

  9. Java数组的声明和遍历

    Java 数组 数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java 语言中提供的数组是用来存储固定大小的同类型元素. 你可以声明一个数组变量,如 n ...

  10. vmware克隆虚拟机后无法联网

    1.基础知识: 就算是克隆的系统,但是由于物理地址改变了,导致rules文件进行了重新绑定 网卡会从eth0变成eth1(逐渐+1),而且mac地址和uuid也会有变化. 2.解决方法: 2.1编辑e ...