zoukankan      html  css  js  c++  java
  • Flask-sqlacodegen

    ORM操作有两种方式。

    1.模型迁移到数据库中生成表,codefirst:使用flask-migrate:

    需要flask-script:

    from flask_script import Manager
    from flask_migrate import Migrate ,MigrateCommand
    from flask import Flask

    app = Flask(__name__)
    manager = Manager(app)  # 注册App到脚本
    Migrate(app,db) # 注册App和ORM对象
    manager.add_command('db',MigrateCommand) # db为命令 即执行python manager.py db 命令

    python manager.py db init:初始化

    python manager.py db migrate:生成迁移脚本

    python manager.py db upgrade:映射到数据库
     
     
     
     

    2.已经建好数据库==>模型:使用flask-sqlacodegen:

    安装:pip install flask-sqlacodegen

    使用window环境下:

    # 整体映射database数据库并写入model.py文件
    flask-sqlacodegen 
    mysql://username:password@127.0.0.1/database 
    --outfile 'model.py' 
    --flask
    
    # 映射table数据表并写入table.py文件
    flask-sqlacodegen 
    mysql://username:password@127.0.0.1/database 
    --table table 
    --outfile 'model.py' 
    --flask

    flask-sqlacodegen mysql://root:@127.0.0.1/db_name --outfile "models/model.py"  --flask

    flask-sqlacodegen mysql://root:@127.0.0.1/db_name --tables user --outfile "models/user.py"  --flask

    常见的一些问题:

    1.执行migrate命令时候出现如下错误,是因为没有检测到models模块的存在,可以在注册蓝图的代码中导入下models

    2.出现 ERROR [alembic.env] Can't locate revision identified by 'a21a614f5bbc'

    删掉数据库中的表: alembic_version

    3.出现找不到路径,重新init一下就好了

  • 相关阅读:
    STM32——项目需求之低功耗的停机模式
    sscanf函数——强大的C语言库函数
    二级指针偏移
    RTX基础教程目录
    #pragma pack(push) 和#pragma pack(pop) 以及#pragma pack()
    Write thread-safe servlets [reproduced]
    C++程序员如何转Java
    How to implement equals() and hashCode() methods in Java[reproduced]
    The Java Enum: A Singleton Pattern [reproduced]
    VS Code
  • 原文地址:https://www.cnblogs.com/xussi/p/10186547.html
Copyright © 2011-2022 走看看