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一下就好了

  • 相关阅读:
    c# 深拷贝与浅拷贝
    SQLServer性能优化 .net开发菜鸟总结
    Ajax自定义无刷新控件实现
    APScheduler库的详细用法
    catkin在centos中的安装
    第五次任务实现与项目总结第六组
    Javascript教程:获取当前地址栏url
    窗口处理问题
    HTML中area标签
    Asp.net中Frameset的使用小结
  • 原文地址:https://www.cnblogs.com/xussi/p/10186547.html
Copyright © 2011-2022 走看看