您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

论坛帖子置顶功能的设计问题

2025/10/1 6:39:32发布59次查看
hi,all
我最近在做一个论坛的推荐功能的时候,不知道该怎么实现会比较好。
需求
管理员可以在后台编辑帖子,帖子可以被推送到首页的推荐位,版块本身的推荐位,还有全局的推荐位(就是每个版块的推荐位都要出现这个帖子)。被推荐的帖子有多种属性类别,比如置顶帖、精华帖等等。初步的实现方案
我用了三张表(common_top_recommend),让管理员可以在后台进行编辑。字段如下:
-- common_top_recommend表id -- 自增idpost_id -- 帖子idtop_recommned_position_id --发布的位置id,关联另外一张位置表,比如首页、版块、全局等type_id --类别id,关联另外一张类型表,比如是精华、置顶、公告等category_id --版块id --common_top_recommend_position表id -- 自增idname -- 显示的名字codename -- 用来匹配的名字,比如index,category,global这样 --common_top_recommend_type表id -- 自增idname -- 显示的名字codename -- 用来匹配的名字,比如top/digest/announce等

比如,查找出某一个版块的置顶帖:
select r.post_id from common_top_recommend as r left join common_top_recommend_position as p on r.top_recommned_position_id=p.id where r.category_id=1 or p.codename=global ;

这样的话,就可以查找出当前版块的置顶贴了。
不过我觉得这样的实现可能有些问题,我参考了下discuz和phpwind的代码,好像都是通过一个display_order字段来完成位置的操作的,但具体实现细节还不是很清楚。
不知道有没更好更轻量的方案呢?
回复内容: hi,all
我最近在做一个论坛的推荐功能的时候,不知道该怎么实现会比较好。
需求
管理员可以在后台编辑帖子,帖子可以被推送到首页的推荐位,版块本身的推荐位,还有全局的推荐位(就是每个版块的推荐位都要出现这个帖子)。被推荐的帖子有多种属性类别,比如置顶帖、精华帖等等。初步的实现方案
我用了三张表(common_top_recommend),让管理员可以在后台进行编辑。字段如下:
-- common_top_recommend表id -- 自增idpost_id -- 帖子idtop_recommned_position_id --发布的位置id,关联另外一张位置表,比如首页、版块、全局等type_id --类别id,关联另外一张类型表,比如是精华、置顶、公告等category_id --版块id --common_top_recommend_position表id -- 自增idname -- 显示的名字codename -- 用来匹配的名字,比如index,category,global这样 --common_top_recommend_type表id -- 自增idname -- 显示的名字codename -- 用来匹配的名字,比如top/digest/announce等

比如,查找出某一个版块的置顶帖:
select r.post_id from common_top_recommend as r left join common_top_recommend_position as p on r.top_recommned_position_id=p.id where r.category_id=1 or p.codename=global ;

这样的话,就可以查找出当前版块的置顶贴了。
不过我觉得这样的实现可能有些问题,我参考了下discuz和phpwind的代码,好像都是通过一个display_order字段来完成位置的操作的,但具体实现细节还不是很清楚。
不知道有没更好更轻量的方案呢?
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product