我有两张表,一张是主题表,一个是回复表。
+------------------+ +------------------+
| forum_topics | | forum_posts |
+------------------+ +------------------+
| topic_id | | post_id |
| topic_title | | post_content |
| topic_contents | | post_date |
| topic_date | | topic_id |
| topic_keywords | | |
+------------------+ +------------------+
我希望这样,当用户查看带有主题的页面并阅读该主题时,它会被标记为特定用户的已阅读。但如果另一个用户来回复那个帖子,我希望它被标记为自上次访问以来的新帖子或类似的东西。
有什么想法吗?
提前谢谢。
你可以通过一个连接到用户和论坛帖子的查找表来做到这一点,如下所示:
当用户查看论坛时,在查找表中输入一行,如
userID, topic_id, post_id, currentTime
然后,为了确定用户是否已经阅读了这个论坛,你可以查询表格,看看他们的用户ID是否出现在其中——这意味着他们已经阅读了它
然后,您可以将currentTime
列与论坛/线程中的最后一个条目进行比较,看看哪个更大,这将告诉您用户是否看到了最后一篇帖子。
编辑:是的,你需要在主题和帖子中添加一个日期时间列(无论如何,知道帖子是什么时候发布的通常是很好的做法),对于一些PHP/SQL:
<?php
$userUpdateTime = gmdate(); // assumed to be either dateTime or unixTimestamp of when user last red the topic/forum
$qry = '
SELECT
IF(`forum_topics`.`updateDateTime` > "'.$userUpdateTime.'", "unRead", "Read")
FROM
`forum_topics` ';
我在论坛上使用以下每个线程每个成员的表:
CREATE TABLE `forum_thread_member` (
`thread_id` mediumint(8) unsigned NOT NULL DEFAULT '0',
`member_id` smallint(5) unsigned NOT NULL DEFAULT '0',
`last_post_id` mediumint(8) unsigned NOT NULL DEFAULT '0',
`read_flag` bit(1) NOT NULL,
`posted_flag` bit(1) NOT NULL,
`new_flag` bit(1) NOT NULL,
`mark_flag` bit(1) NOT NULL,
`bookmark_flag` bit(1) NOT NULL,
`hidden_flag` bit(1) NOT NULL,
PRIMARY KEY (`thread_id`,`member_id`),
KEY `bookmark_flag` (`bookmark_flag`)
)
在查询线程列表时,我在上面留下了join。如果值是NULL
,那么线程还没有被读取。这可以让你确切地知道一个人阅读并参与了哪些线程
last_post_id
非常有用,因为您可以直观地跳转到并显示此人阅读的最后一篇文章。每次有人发帖时,new_flag
都设置为1
,因此可以很容易地用于直观地确定线程列表是否有新的(未读的)内容。其他标志用于管理书签、隐藏线程等。
当然,这个表可能会变得很大,但只要没有设置任何重要标志(例如bookmark_flag
),就可以安全地删除旧记录。如果一个人搜索或浏览旧线程,你可以假设它们已经被读取(而不是像搜索新线程那样假设它们未读)。