Advertisement

Python Flask框架 -- flask-migrate迁移ORM模型

阅读量:

下面正式开始:

第一步:

复制代码
    # ORM模型映射成表的三步(在项目终端执行)
    # 1.flask db init (类似于git仓库初始化),这步只需要执行一次
    
    
      
      
    

执行前:

执行后在项目中会多出一个文件夹migrations,这是迁移脚本初始化:

第二步:

复制代码
    # 2.flask db migrate 识别ORM模型的改变,生成迁移脚本
    
    
      
    

执行前,versions文件夹里面是空的:

执行后就会看到versions里面生成了脚本:

第三步:

复制代码
    # 3.flask db upgrade 运行迁移脚本,同步到数据库中
    
    
      
    

运行前数据库中为空:

运行后:

刷新数据库就可以看到同步过来的表了:

其中alembic_version是用来记录迁移脚本版本号的

此时可以看到email已经创建成功:

如果我们要新增一个字段signature:

复制代码
    class User(db.Model):
    __tablename__ = 'user'
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    username = db.Column(db.String(100), nullable=False)
    password = db.Column(db.String(100), nullable=False)
    email = db.Column(db.String(100))
    signature = db.Column(db.String(100))
    
    
      
      
      
      
      
      
      
    

分别在终端执行第二第三步就行了:

复制代码
    # 2.flask db migrate 识别ORM模型的改变,生成迁移脚本
    # 3.flask db upgrade 运行迁移脚本,同步到数据库中
    
    
      
      
    

执行后在数据库中刷新就能看到新增的字段了:

app.py 完整代码:

复制代码
    from flask import Flask
    from flask_sqlalchemy import SQLAlchemy
    from flask_migrate import Migrate
    
    app = Flask(__name__)
    
    # MySQL所在的主机名或域名
    HOSTNAME = '127.0.0.1'
    # MySQL监听的端口号,默认3306
    PORT = 3306
    # 连接MySQL的用户名,用自己的
    USERNAME = 'root'
    # 连接MySQL的密码,用自己的
    PASSWORD = '***'
    # MySQL上创建的数据库名称
    DATABASE = 'database_learn'
    
    app.config[
    'SQLALCHEMY_DATABASE_URI'] = f'mysql+pymysql://{USERNAME}:{PASSWORD}@{HOSTNAME}:{PORT}/{DATABASE}?charset=utf8mb4'
    
    # 在app.config中设置好连接数据库的信息
    # 然后使用SQLAlchemy(app)创建一个db对象
    # SQLAlchemy会自动读取app.config中连接数据库的信息
    db = SQLAlchemy(app)
    
    # 创建对象,使用它来将ORM模型映射到数据库
    migrate = Migrate(app, db)
    
    # ORM模型映射成表的三步(在项目终端执行)
    # 1.flask db init (类似于git仓库初始化),这步只需要执行一次
    # 2.flask db migrate 识别ORM模型的改变,生成迁移脚本
    # 3.flask db upgrade 运行迁移脚本,同步到数据库中
    
    
    class User(db.Model):
     **自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。** **深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!** **因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**
![img]()
![img]()
![img]()
![img]()
![img]()
![img]()
    
    **既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!** **由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新** **如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)**
    
    习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!** **由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新** **如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)**
    
    <img src="" alt="img" style="zoom:50%;" />
    
    
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
      
    

全部评论 (0)

还没有任何评论哟~