SQLAlchemy 数据库迁移错误 db.relationships
SQLAlchemy database migration error with db.relationships
我在使用 db.relationship 时尝试 "flask db init" 或 "flask run" 时不断收到以下错误:
TypeError: relationship() got an unexpected keyword argument 'query_class'
如果我注释掉 db.relationship 行,它工作正常。
我试图通过使用他们下面的部分文档代码来实现这一点:
import os
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate
app = Flask(__name__)
app.config['SECRET_KEY'] = 'mysecretkey'
basedir = os.path.abspath(os.path.dirname(__file__))
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///'+os.path.join(basedir,'data.sqlite')
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)
Migrate(app,db)
class Person(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(50), nullable=False)
addresses = db.relationship('Address', backref='person', lazy=True)
class Address(db.Model):
id = db.Column(db.Integer, primary_key=True)
email = db.Column(db.String(120), nullable=False)
person_id = db.Column(db.Integer, db.ForeignKey('person.id'),
nullable=False)
环境:
- 烧瓶 1.1.2
- 烧瓶迁移 2.5.3
- Flask-SQLAlchemy 2.4.3
- SQLAlchemy 1.3.17
- PyCharm 2020.1.1
- Windows 7
我通过卸载 Flask、Flask-Migrate 和 SQLAlchemy 然后重新安装它们设法解决了这个问题。
#Uninstall
pip uninstall Flask
pip uninstall Flask-Migrate
pip uninstall SQLAlchemy
#Install
pip install Flask
pip install Flask-Migrate
pip install SQLAlchemy
我在使用 db.relationship 时尝试 "flask db init" 或 "flask run" 时不断收到以下错误:
TypeError: relationship() got an unexpected keyword argument 'query_class'
如果我注释掉 db.relationship 行,它工作正常。
我试图通过使用他们下面的部分文档代码来实现这一点:
import os
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate
app = Flask(__name__)
app.config['SECRET_KEY'] = 'mysecretkey'
basedir = os.path.abspath(os.path.dirname(__file__))
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///'+os.path.join(basedir,'data.sqlite')
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)
Migrate(app,db)
class Person(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(50), nullable=False)
addresses = db.relationship('Address', backref='person', lazy=True)
class Address(db.Model):
id = db.Column(db.Integer, primary_key=True)
email = db.Column(db.String(120), nullable=False)
person_id = db.Column(db.Integer, db.ForeignKey('person.id'),
nullable=False)
环境:
- 烧瓶 1.1.2
- 烧瓶迁移 2.5.3
- Flask-SQLAlchemy 2.4.3
- SQLAlchemy 1.3.17
- PyCharm 2020.1.1
- Windows 7
我通过卸载 Flask、Flask-Migrate 和 SQLAlchemy 然后重新安装它们设法解决了这个问题。
#Uninstall
pip uninstall Flask
pip uninstall Flask-Migrate
pip uninstall SQLAlchemy
#Install
pip install Flask
pip install Flask-Migrate
pip install SQLAlchemy