当用户阅读论坛时,将其标记为已读,然后在发布新回复时,将论坛标记为新论坛



我有两张表,一张是主题表,一个是回复表。

+------------------+     +------------------+
| 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),就可以安全地删除旧记录。如果一个人搜索或浏览旧线程,你可以假设它们已经被读取(而不是像搜索新线程那样假设它们未读)。

相关内容

  • 没有找到相关文章

最新更新