2

我是 sqlalchemy 的新手。现在用 Flask 开发网站。我想用线程组织消息系统。类似于 facebook 对话框之类的东西。我有以下模型,并且此代码有效:

message_read_state_relations = db.Table('message_message_read_state_relations',
        db.Column('user_id', db.Integer, db.ForeignKey('auth_users.id')),
        db.Column('message_id', db.Integer, db.ForeignKey('messages.id')),
)

class User(db.Model):
        __tablename__ = 'auth_users'

        id = db.Column(db.Integer, primary_key=True)
        email = db.Column(db.String(100))
        password = db.Column(db.String(100))

        messages = db.relationship('Message', backref=db.backref('user'), lazy='dynamic')

        threads = association_proxy('user_thread_relations', 'thread')


class Message(db.Model):
        __tablename__ = 'messages'

        id = db.Column(db.Integer, primary_key=True)
        text = db.Column(db.Text, default='')

        thread_id = db.Column(db.Integer, db.ForeignKey('threads.id'))
        user_id = db.Column(db.Integer, db.ForeignKey('auth_users.id'))

        user_read_states = db.relationship('User', secondary=message_read_state_relations,
                backref=db.backref('message_read_states'), lazy='joined')


class Thread(db.Model):
        __tablename__ = 'threads'

        id = db.Column(db.Integer, primary_key=True)
        subject = db.Column(db.String(255))

        messages = db.relationship('Message', backref=db.backref('thread'), lazy='dynamic')
        users = association_proxy('user_thread_relations', 'user')


class UserThreadRelation(db.Model):
        __tablename__ = 'user_thread_relations'

        user_id = db.Column(db.Integer, db.ForeignKey('auth_users.id'), primary_key=True)
        thread_id = db.Column(db.Integer, db.ForeignKey('threads.id'), primary_key=True)

        is_deleted = db.Column(db.Boolean, default=False)

        user = db.relationship(User, backref=db.backref('user_thread_relations'))
        thread = db.relationship(Thread, backref=db.backref('user_thread_relations'))

但是有些东西我看不懂。例如,如何获取用户的所有未读消息计数?或者在某些线程中未读消息对用户计数?

MessageUser与via有关系message_read_state_relations。如何获取属于该用户而不属于message_read_state_relations该用户的所有线程的所有消息?

或者,也许,我做错了?设计错了吗?我基于这个问题线程消息系统数据库架构设计创建它

谢谢你的帮助!

4

2 回答 2

1

不知道这是否是最好的设计,似乎是合理的。关于您询问的查询,它们可以使用连接和子查询构建,您可能想在 SQLAlchemy 文档中阅读它们。我还建议熟悉此类查询的纯 SQL 方法,因为 SA 试图非常密切地遵循 SQL,而理解 SQL 有助于极大地编写 SA 查询。这是一个查询的示例(获取用户的所有未读消息计数):

# First count all the messages.
# On a big set of data this may be very slow operation.
total_msgs = db.session.query(db.func.count(Message.id).label('cnt')).subquery()
# Then count messages read by the user.
read_msgs = db.session.query(db.func.count(Message.id).label('cnt')).\
    join(User.message_read_states).filter(User.id == 1).subquery()
# Subtract read messages count from total count.
unread_count = db.session.query(total_msgs.c.cnt - read_msgs.c.cnt).scalar()
于 2013-01-27T12:24:35.290 回答
0

我也在尝试使用 Flask 和 sqlalchemy 开发一个线程消息系统。搜索我找到了你的问题和 django 的 github 存储库(下面的链接)。我认为该模型可能非常有用。如果您仍然感兴趣(6 年后),请给我留言。

https://github.com/philippWassibauer/django-threaded-messages/blob/master/threaded_messages/models.py

于 2019-02-23T12:29:39.950 回答