[英]Sql alchemy sqlalchemy.exc.NoReferencedTableError not creating tables
我正在使用flask並嘗試學習sqlalchemy,我有一個數據庫,我在其中添加了第三個表來創建新功能,但整個項目停止工作,它說:
sqlalchemy.exc.NoReferencedTableError: Foreign key associated with column 'url_reference.folder_rel' could not find table 'reffolders' with which to generate a foreign key to target column 'id'
這是dbs.py
from . import db
from flask_login import UserMixin
from sqlalchemy.sql import func
class User(db.Model, UserMixin):
id = db.Column(db.Integer, primary_key=True)
email = db.Column(db.String(200), unique=True)
user_password = db.Column(db.String(150))
user_name = db.Column(db.String(400))
user_refs = db.relationship("RefFolders")
class RefFolders(db.Model):
id = db.Column(db.Integer, primary_key=True)
folder_title = db.Column(db.String(1000))
date_added = db.Column(db.DateTime(timezone=True), default=func.now())
user_rel = db.Column(db.Integer, db.ForeignKey("user.id"))
url_rel = db.relationship("UrlReference")
class UrlReference(db.Model):
id = db.Column(db.Integer, primary_key=True)
ref_title = db.Column(db.String(1000))
ref_url = db.Column(db.String(30000))
date_added = db.Column(db.DateTime(timezone=True), default=func.now())
folder_rel = db.Column(db.Integer, db.ForeignKey("reffolders.id"))
這是我在__init__.py
創建數據庫的地方:
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from os import path
from flask_login import LoginManager
db = SQLAlchemy()
DB_NAME = "database.db"
def app():
app = Flask(__name__)
app.config['SECRET_KEY'] = '<here is the key in my code>'
app.config['SQLALCHEMY_DATABASE_URI'] = f"sqlite:///{DB_NAME}"
db.init_app(app)
# making the blueprints usable
from .views import views
from .auth import auth
app.register_blueprint(views, url_prefix="/")
app.register_blueprint(auth, url_prefix="/")
from .dbs import User
from .dbs import UrlReference
from .dbs import RefFolders
db_create(app)
# Login manager
login_manager= LoginManager()
login_manager.login_view = 'views.home'
login_manager.init_app(app)
# Searching and loading user
@login_manager.user_loader
def load_user(id):
return User.query.get(int(id))
return app
def db_create(app):
if not path.exists("project/" + DB_NAME):
db.create_all(app=app)
我不知道發生了什么,也許是雙外鍵的問題?
我認為flask或其擴展名會猜測您想要的表名,例如CamelCase --> camel_case。
所以在這種情況下,表名可能是ref_folders
。 您可能只想使用tablename自己設置表名,盡管我認為它們的默認值是一個很好的約定。
作為旁注,我建議使用_id
作為您的 id,否則對象關系和實際 id 之間的事情可能會變得非常混亂,即。 使用user_id
代替user_rel
在RefFolders
。
看:
https://flask-sqlalchemy.palletsprojects.com/en/2.x/models/#declaring-models
SQLAlchemy 中需要的一些部分在 Flask-SQLAlchemy 中是可選的。 例如,除非被覆蓋,否則會自動為您設置表名。 它派生自轉換為小寫的類名,並將“CamelCase”轉換為“camel_case”。 要覆蓋表名,請設置
__tablename__
類屬性。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.