簡體   English   中英

Sql alchemy sqlalchemy.exc.NoReferencedTableError 不創建表

[英]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_relRefFolders

看:

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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM