python--Flask学习(六)--flask-script和flask-migrate

1、flask_script的用法
(1)Flask-script的作用是可以通过命令的形式来操作flask,例如通过命令跑一个开发版本的服务器、设置数据库,定时任务等。
(2)如果直接在主‘manage.py’中写命令,那么在终端只需要输入python manage.py runserver就能执行。
(3)如果把一些命令集合在一个文件中,那么终端就需要输入一个父命令,如:python manage.py db init
示例代码:
manage.py

rom flask_script import Manager
from flask_script_demo import app
from db_scripts import DBManager
# 和数据库相关的操作都放在一起

manager = Manager(app)

@manager.command
def runserver():
    print('server is running')

manager.add_command('db',DBManager)
#add.command的第一个参数是命令的前缀
if __name__ == '__main__':
    manager.run()

有子命令的例子 db_script.py

from flask_script import Manager

DBManager = Manager()

@DBManager.command
def init():
    print('Database initialization is complete.')

@DBManager.command
def migrate():
    print('Database is migrate successfully.')

在这里插入图片描述2、flask-migrate的用法
前面学利用db.create_all创建一个表运行后会将表内的信息都存到数据库中去,如果之后在添加信息再次运行,此数据是不会被存到表中去的,之前想要在添加新的信息到数据库,使用的是drop table 表名这条命令来将原先的表删除再运行建立一张新的添加进去信息的表。

因为采用db.create_all在后期修改字段的时候,不会自动更改到数据库中,必须删除表,然后重新运行db.create_all才会重新映射,这样是不符合实际情况的。因此flask-migrate就解决了这个问题,可以直接将修改的东西映射到数据库中

(1)使用flask-migrate必须借助flask-scripts,这个包MigrateCommand中包含了所有和数据库相关的命令。
(2)flask-migrate`相关命令:

  • python manage.py db init:初始化一个迁移脚本的环境,只需要执行一次。
  • python manage.py db migrate:将模型生成迁移文件,只要模型更改了,就需要执行一次这个命令。
  • python manage.py db upgrade:将迁移文件真正的映射到数据库中。每次也需要执行一次这个命令。
    注意:
    需要将你想要映射到数据库中的模型,都要导入到manage.py文件中,如果没有导入进去,就不会映射到数据库中。
    示例代码如下:
    migrate.py
from flask import Flask
from exts import db
import config
from models import Article

app = Flask(__name__)
app.config.from_object(config)
db.init_app(app)
#app文件是个堆栈,我们手动加进里面,不然无法运行

# with app.app_context():
#     db.create_all()
# 新建一个article模型,采用models分开的方式
# flask-script的方式


@app.route('/')
def hello_world():
    return 'Hello World!'


if __name__ == '__main__':
    app.run(debug = True)

manage.py--------将你想要映射到数据库中的模型,都导入到该文件中

from flask_script import Manager
from migrate_demo import app
from flask_migrate import Migrate, MigrateCommand
from exts import db
from models import Article
# python3 manage.py db init  ---初始化环境
# python3 manage.py db migrate  ---将模型生成一个迁移文件
# python3 managepy db upgrade   ---将模型真正的映射到数据库中去
#模型 -->  迁移文件 --> 表

manager = Manager(app)

# 1.要使用flask_migrate,必须绑定app和db
migrate = Migrate(app, db)

# 2.把MigrateCommand命令添加到manager中
manager.add_command('db', MigrateCommand)


if __name__ == '__main__':
    manager.run()


exts.py-------因为文件和文件之间会产生循环引用,通过这个文件可以消除循环引用

from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()

models.py------在这个py文件中,我们通过这个py文件中的类创建数据库

from flask import Flask
from exts import db

class Article(db.Model):
    __tablename__ ='article'
    id = db.Column(db.Integer,primary_key= True,autoincrement=True)
    title = db.Column(db.String(100),nullable=False)
    content = db.Column(db.Text,nullable=False)
    tags = db.Column(db.String(100),nullable=False)

config.py------配置文件
在这个文件里面是对配置一系列进行操作,比如数据库、debug之类的

import os
DIALCT = "mysql"
DRIVER = "pymysql"
USERNAME = "root"
PASSWORD = "root"
HOST = "127.0.0.1"
PORT = "3306"
DATABASE = "migrate_demo"
DB_URI = "{}+{}://{}:{}@{}:{}/{}?charset=utf8".format(DIALCT, DRIVER, USERNAME, PASSWORD, HOST, PORT, DATABASE)
SQLALCHEMY_DATABASE_URI = DB_URI
SQLALCHEMY_TRACK_MODIFICATIONS = True
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值