Flask-sqlacodegen

时间:2023-03-09 02:38:49
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

Flask-sqlacodegen

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

删掉数据库中的表: alembic_version

Flask-sqlacodegen

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

Flask-sqlacodegen