169 похожих чатов

Вопрос по sqlalchemy и отношением сущностей есть 2 сущности(таблицы) users и

messages
у user'a может быть много messages или не быть вообще

как это описать правильно?
если нет messages - нужно отдавать в объекте User.messages пустой лист

class User(Base):
__tablename__ = "user"

id = Column(BigInteger, primary_key=True, unique=True, autoincrement=False)
name = Column(String, nullable=False)
messages = relationship("Message", backref='user')


class Message(Base):
__tablename__ = "message"

id = Column(BigInteger, primary_key=True, unique=True, autoincrement=true)
user_id = Column(ForeignKey("user.id"), nullable=False)
text = Column(Text, nullable=False)


Ошибка:
sqlalchemy.orm.exc.DetachedInstanceError: Parent instance <User at 0x1e0c9bde530> is not bound to a Session; lazy load operation of attribute 'messages' cannot proceed (Background on this error at: https://sqlalche.me/e/14/bhk3)

Инициализация сессии:
async_sessionmaker = sessionmaker(
engine, expire_on_commit=False, class_=AsyncSession
)

Добавляю нового пользователя так:
await session.merge(User(
id=id,
name=name
))
await session.commit()

1 ответов

13 просмотров

С алхимией в https://t.me/sqlalchemy_help

Похожие вопросы

Обсуждают сегодня

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
28
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
День добрый, подскажите пожалуйста, есть ли какой-то способ сказать ребару не компилировать определённое приложение? Всю доку их перечиатл ничего подобного не нашёл
Кирилл
14
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
10
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
В clientsettings есть поле client_rates. В поле pagebuilder. Как получить то его?)
Andrey K
8
Здравствуйте, хочу сделать HelloWorld в консоли Дельфи, но функция API ничего не выводит, что я делаю не так? program Hello; {$APPTYPE CONSOLE} uses System.SysUtils, WinAPI.Wi...
Sergey Vinogradov
20
Вопрос на перед, на следующую пятницу. Сколько строк кода можно вешать на одного программиста, понятно что если проект хорошо написан то можно и миллион. Но есть же где то пре...
AlekseyK Kluchnikov
31
Немного оффтопа: а кто на чем сидит для осдева в плане ide/редактора? Последнее время сидел на vscode, но я его прям не могу нормально воспринимать, перешел на сlion, но меня...
Evg Resh
29
Карта сайта