login8226 2012-09-01 09:14
浏览 219
已采纳

类似于微博 用户最后一条动态的查询

有一个用户动态表 feed :

user_who_id和user_whose_id都是user表的外键 指向user表

一个好友关注表 concern :

fans_id和follow_id都是user表的外键 指向user表

 

这个时候我需要查询出所有我关注的好友,并显示他们的最后一条动态.


类似于上面这种形式.

之前的一种做法是 查出好友,然后根据好友id去查询出好友最后一条动态,然后塞到好友对象中,也就是在concern中加一个不持久化的属性  lastFeed

这样的话还好做些,但是有个需求就是根据好友最后动态的更新时间来进行我好友的排序.

 

之前的做法就是根据我的好友进行分组查出好友最后一条动态 并根据动态创建时间排序.

 

select f3 from Feed f3 where f3.id in(select max(f2.id) from Feed f2 where f2.id in(select f1.id from Feed f1 where f1.who.id in(select c.follow.id from Concern c where c.fans.id=<我> and c.isFriends=1)  order by f1.id desc) group by f2.who.id) order by f3.id desc

 然后再根据动态中的user_who_id(动态的产生者)去查询concern,然后再将lastFeed放到concern中传到前台.

这样做感觉很烂,效率不好,而且很麻烦.

 

 

后来想到一种做法,就是在 user表中加一个字段 last_feed_id 就是用户的最后一条动态的id.是个外键.相当于user表示子表,feed表就是主表.

 

这样查询很方便,hibernate中直接concern.follow.lastFeed即可.

排序的话根据lastFeed的时间排序即可.

 

但是目前遇到的问题就是更新时很麻烦,例如(用户评论了一篇文章) 如果这篇文章被删除,那么相应的评论动态都要删掉.这时候就需要更新user表的最后一条动态.

因为Feed表这时是主表,user变成从表,删除feed时 可能会有外间约束,删不掉.还必须先解除外间关系,再删feed,然后再查询出最后一条动态,更新到user表中.

 

感觉这两种都不咋地啊,有没有别的更好的设计方法?

 

 

 

  • 写回答

1条回答 默认 最新

  • jinnianshilongnian 2012-09-01 09:58
    关注

    1、专门建立一个最新动态表; 每个用户只存一个动态; 主键就是用户id

    2、可以使用触发器更新这张表;

    3、mysql有这么一个语句 merge into
    mysql有一个replace into的dml语句,类似insert,但是会在insert之前检查表的唯一索引或主键。如果存在,就改为update操作。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何让子窗口鼠标滚动独立,不要传递消息给主窗口
  • ¥15 如何能达到用ping0.cc检测成这样?如图
  • ¥15 关于#DMA固件#的问题,请各位专家解答!
  • ¥15 matlab生成的x1图不趋于稳定,之后的图像是稳定的水平线
  • ¥15 请问华为OD岗位的内部职业发展通道都有哪些,以及各个级别晋升的要求
  • ¥20 微信小程序 canvas 问题
  • ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
  • ¥15 怎么把512还原为520格式
  • ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
  • ¥15 求高通平台Softsim调试经验