Похожие чаты

Всем привет, нуждаюсь в помощи. Делаю типа связей юзера и его

френдов
class User:
connections = relationship('Connection', foreign_keys=[Connection.user_id], back_populates='friend')
friends = relationship(
'User',
secondary='connection',
primaryjoin=and_(id == Connection.user_id, Connection.status == ConnectionStatus.connected),
secondaryjoin=id == Connection.friend_id
)

class Connection(ModelBase):
__tablename__ = 'connection'

__table_args__ = (
UniqueConstraint('user_id', 'friend_id', name='_user_friend_uc'),
)
id = Column(Integer, primary_key=True)
user_id = Column(UUID(as_uuid=True), ForeignKey('users.id'))
friend_id = Column(UUID(as_uuid=True), ForeignKey('users.id'))
status = Column(Enum(ConnectionStatus), nullable=False)
user = relationship('User', foreign_keys=[user_id])
friend = relationship('User', foreign_keys=[friend_id], back_populates='connections')

Представим что есть юзер_1 и юзер_2
юзер_1 отправил инвайт юзеру_2
Connection(user=user_1, friend=user_2)
Если текущий юзер = user_1 -> user.friends / user.connections будет работать как должно, но если текущий юзер = user_2, у меня будут пустые релейшены френдов и конекшенов.
Я вот думаю или делать конекшен "в обе стороны", типа в момент создания делать вот так:
Connection(user=user_1, friend=user_2)
Connection(user=user_2, friend=user_1) (но мне кажется это полный бред)
Или можно попробовать поправить что-то в релейшенах? Но я не понимаю что и как именно нужно поправлять. Либо у меня структура БД вообще не правильная... Как это делается? Памагите пожалуйста

3 ответов

20 просмотров
Daniel-Daniel Автор вопроса

Тишка, глянь пожалуйста 🥺

Daniel-Daniel Автор вопроса

я подождал пока холивар успокоится и все к чему-то общему придут. И начнут хейтить меня)))) Реально, пацаны, если я долбоеб так и скажите

Хранить лишние строки в бд выглядит так себе. Чтобы релейшены поправить, можешь написать кастомный prymaryjoin

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
@Benzenoid can you tell me the easiest, and safest way to bu.y HEX now?
Živa Žena
20
This is a question from my wife who make a fortune with memes 😂😂 About the Migration and Tokens: 1. How will the old tokens be migrated to the new $LGCYX network? What is th...
🍿 °anton°
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
What is the Dex situation? Agora team started with the Pnetwork for their dex which helped them both with integration. It’s completed but as you can see from the Pnetwork ann...
Ben
1
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Anyone knows where there are some instructions or discort about failed bridge transactions ?
Jochem
21
@lozuk how do I get my phex copies of my ehex from a atomic wallet, to move to my rabby?
Justfrontin 👀
11
Карта сайта