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

有一个用户动态表 feed :

40f872d669227ec000022b1b81a9600c.png

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

一个好友关注表 concern :

ea20bcf3c8109f49d20f45c4462b10cc.png

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

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

ae62b763cabf45e3b6432000b0d71314.png

类似于上面这种形式.

之前的一种做法是 查出好友,然后根据好友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表中.

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值