gpt4 book ai didi

python - 初始化映射器映射的 SQLAlchemy 时出错

转载 作者:行者123 更新时间:2023-12-04 12:03:01 25 4
gpt4 key购买 nike

我有一张表,该表在一对多的关系中引用了另外 2 个表。

我已经尝试了很多东西,但我找不到我想做的类似的例子。下面是发生错误时的代码和说明。

对话.py:

from .model import db
from sqlalchemy.dialects.postgresql import JSON

class Conversa(db.Model):
__tablename__ = "conversas"
id = db.Column('ConversaId',db.Integer, primary_key=True)
fkEmpresa = db.Column('FkEmpresa', db.Integer, db.ForeignKey('empresas.empresaId'),nullable=False)
fkTipoUsuario = db.Column('FKTipoUsuario', db.Integer,db.ForeignKey('tiposUsuarios.tipoUsuarioId'),nullable=False)
# other fields

Empresas.py:
从 .model 导入数据库
class Empresa(db.Model):
__tablename__ = "empresas"
id = db.Column('empresaId',db.Integer, primary_key=True)
#some fields
empresaCaracteristicas = db.relationship('EmpresaCaracteristica', backref='empresas', lazy=True)
conversas = db.relationship('Conversa', backref='empresas', lazy=True)

TipoUsuario.py:
class TipoUsuario(db.Model):
__tablename__ = "tiposUsuarios"
id = db.Column('tipoUsuarioId',db.Integer, primary_key=True)
#some fields
usuarios = db.relationship('Usuario', backref='tiposUsuarios', lazy=True)
conversas = db.relationship('Conversa', backref='tiposUsuarios', lazy=True)

我试图插入一些值,但发生此错误:
sqlalchemy.exc.InvalidRequestError: When initializing mapper mapped failed to locate a name ("name '' is not defined"). If this is a class name, consider adding this relationship() to the <class 'banco_nestorgr.tabelas.tipoUsuarioModel.TipoUsuario'> class after both dependent classes have been defined

最佳答案

类 TipoUsuario(db.Model): 中的 backref 不应该相同
尝试重命名 backref

关于python - 初始化映射器映射的 SQLAlchemy 时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57907878/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com