做自己,因为别人都在做自己。
– Oscar Wilde
这是我新博客的第一篇文章。我刚开始写这个新博客,因此请继续关注。在下方订阅,以便在我更新新文章时您会收到通知。
python学习
做自己,因为别人都在做自己。
– Oscar Wilde
这是我新博客的第一篇文章。我刚开始写这个新博客,因此请继续关注。在下方订阅,以便在我更新新文章时您会收到通知。
flask_migrate英文文档翻译
Flask
Flask-Migrate是用于使用Alembic处理Flask应用程序的SQLAlchemy数据库迁移的扩展。可通过Flask命令行界面或Flask-Script扩展名使用数据库操作。
为什么直接使用Flask-Migrate与Alembic?
Flask-Migrate是一个扩展,它以正确的方式配置Alembic以与Flask和Flask-SQLAlchemy应用程序一起使用。就实际的数据库迁移而言,一切都由Alembic处理,因此您可以获得完全相同的功能。
Installation
用pip安装Flask-Migrate :
pip install Flask-Migrate
Example
这是一个通过Flask-Migrate处理数据库迁移的示例应用程序:
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate
app = Flask(name)
app.config[‘SQLALCHEMY_DATABASE_URI’] = ‘sqlite:///app.db’
app.config[‘SQLALCHEMY_TRACK_MODIFICATIONS’] = False //这里是自己加上的为了去掉警告部分
db = SQLAlchemy(app)
migrate = Migrate(app, db)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(128))
1
2
3
4
5
6
7
8
9
10
11
12
13
使用上述应用程序,您可以使用以下命令创建迁移存储库:
$ flask db init
这会将一个迁移文件夹添加到您的应用程序。该文件夹的内容需要与其他源文件一起添加到版本控制中。
然后,您可以生成初始迁移:
$ flask db migrate
迁移脚本需要进行检查和编辑,因为Alembic当前无法检测到您对模型所做的每项更改。特别是,Alembic当前无法检测表名称更改,列名称更改或匿名命名的约束。限制的详细摘要可在Alembic自动生成文档中找到。完成后,还需要将迁移脚本添加到版本控制中。
然后,您可以将迁移应用于数据库:
$ flask db upgrade
然后,每次数据库模型更改时,重复migrate和upgrade命令。
要在另一个系统中同步数据库,只需从源代码管理中刷新迁移文件夹并运行upgrade命令。
要查看所有可用命令,请运行以下命令:
$ flask db –help
请注意,必须按照命令行脚本的FLASK_APP要求,在环境变量中设置应用程序脚本,以上所有命令才能起作用flask。
使用Flask- Script
Flask-Migrate还支持Flask-Script命令行界面。这是一个示例应用程序,通过Flask-Script公开了所有数据库迁移命令:
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_script import Manager
from flask_migrate import Migrate, MigrateCommand
app = Flask(name)
app.config[‘SQLALCHEMY_DATABASE_URI’] = ‘sqlite:///app.db’
db = SQLAlchemy(app)
migrate = Migrate(app, db)
manager = Manager(app)
manager.add_command(‘db’, MigrateCommand)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(128))
if name__ == ‘__main‘:
manager.run()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
假设以上脚本存储在名为的文件中manage.py,则可以通过运行脚本来访问所有数据库迁移命令:
$ python manage.py db init
$ python manage.py db migrate
$ python manage.py db upgrade
$ python manage.py db –help
配置回调
有时,应用程序需要将自己的设置动态插入Alembic配置中。configure在读取配置之后和使用配置之前,将调用以回调装饰的函数。该功能可以修改配置对象,或将其替换为其他对象。
@migrate.configure
def configure_alembic(config):
# modify config object
return config
1
2
3
4
多数据库支持
Flask-Migrate可以与Flask-SQLAlchemy 的绑定功能集成在一起 ,从而可以跟踪到与应用程序关联的多个数据库的迁移。
要创建多数据库迁移存储库,请将–multidb参数添加到init命令中:
$ flask db init –multidb
使用此命令,将建立迁移存储库以跟踪主数据库以及SQLALCHEMY_BINDS配置选项中定义的任何其他数据库上的迁移
这是一篇示例文章,最初作为 Blogging University 的组成部分发布。报名参加我们十个项目中的其中一个,立即开始撰写您的博客。
您今天要发布一篇文章。不必担心您的博客的外观。如果您还没有给博客命名或是感到不知所措,也不必担心。只需点击“新文章”按钮,告诉我们您来此处的原因。
为什么要这样做?
文章可短可长,可以是对您的生活的个性化介绍或是博客宗旨说明,也可以是对未来的宣言或是对希望发布的内容类型的简要概述。
为了帮助您开始撰写,不妨思考以下几个问题:
您并非一定要受此限制,博客的一个奇妙之处在于,随着我们学习、成长和与他人互动,它们是会不断演变的,不过如果知道从何处入手以及为何开始,这将会颇有益处,并且明确您的目标可能会激发您写其他一些文章的灵感。
不知道如何开始?只需写下您脑海中闪现的第一件事即可。Anne Lamott 是一位作家,大家都喜欢她写的书。她指出,你要允许自己写出“蹩脚的初稿”。Anne 提出了一个很好的观点,先开始写,之后再去考虑如何编辑。
在您准备发布时,给您的文章贴上三到五个标签来描述您博客的关注点 – 写作、摄影、小说、育儿、美食、汽车、电影、体育等。这些标签将帮助关注您话题的人在阅读器中找到您。确保添加“zerotohero”标签,这样其他新博主也可以找到您。