免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4825 | 回复: 17
打印 上一主题 下一主题

如何用一条语句实现我需要的查询结果  关闭 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-25 09:40 |只看该作者 |倒序浏览
10可用积分
先说明一下情况,有这样的一个表,用来存储我喜欢的人和喜欢我的人。主要有三个字段:suid_FK,tuid_FK,ctime,分别表示喜欢者的uid,被喜欢者的uid,喜欢的时间(datetime)格式,前两个都是int类型。
现在我想选出既是我喜欢的,又是喜欢我的记录,就像下面:
id        suid_FK         tuid_FK                 ctime
1        123                  789                2008-08-25 22:30:25
2        123                  456                2008-08-24 22:30:25
3        123                  987                2008-08-23 22:30:25
4        456                  123                2008-08-25 09:30:21
5        123                  543                2008-08-24 22:30:25
6        888                  123                2008-08-26 09:30:21
7        123                  543                2008-08-24 22:30:25
8        123                  888               2008-08-25 09:30:21



早上可能没把问题说清楚,现在再补充了一点,加了几条记录
标红色的那四条记录,说明我喜欢她,她又喜欢我,那么我取的应该是id号为4和id号为6的记录。因为2,4一样,但4的ctime比2的ctime大,
同理,6、8一样,但6的ctime比8的ctime大。

不知道我这样说明了问题没有?没有我再补充。请大虾指教。
分数有限,请见谅.

[ 本帖最后由 jackywdx 于 2008-8-25 14:40 编辑 ]

最佳答案

查看完整内容

select * from test a where a.tuid_fk in (select suid_fk from test b where a.suid_fk=b.tuid_fk) and rownum=1 order by ctime这样可以不?我也才学弄不大明白..[ 本帖最后由 crosslife 于 2008-8-25 13:30 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-08-25 09:40 |只看该作者
select * from test a where a.tuid_fk in (select suid_fk from test b where a
.suid_fk=b.tuid_fk) and rownum=1 order by ctime
这样可以不?我也才学弄不大明白..

[ 本帖最后由 crosslife 于 2008-8-25 13:30 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2008-08-25 11:26 |只看该作者
select * from table order by ctime desc limit 1;

论坛徽章:
0
4 [报告]
发表于 2008-08-25 12:20 |只看该作者

楼上的没有看明白题目意思吧,这样取出来的肯定不对啦,后面还有很多其它记录的。

论坛徽章:
1
白银圣斗士
日期:2015-11-23 08:33:04
5 [报告]
发表于 2008-08-25 12:55 |只看该作者
原帖由 jackywdx 于 2008-8-25 12:20 发表

楼上的没有看明白题目意思吧,这样取出来的肯定不对啦,后面还有很多其它记录的。


你试下就知道了。从你主贴上写的意思,2楼写的没的错啊

论坛徽章:
0
6 [报告]
发表于 2008-08-25 14:51 |只看该作者

回复 #2 crosslife 的帖子

谢谢2楼,刚才测试了一下,好像找出了那些记录。
再补充一个问题,我想根据当前登录用户的uid来找出既是他喜欢的,又是喜欢他的,应该如何改这条语句。

[ 本帖最后由 jackywdx 于 2008-8-25 14:52 编辑 ]

论坛徽章:
0
7 [报告]
发表于 2008-08-25 15:13 |只看该作者

回复 #6 jackywdx 的帖子

select *  from test  where tudi_fk in (select tuid_fk from test where suid_fk=youruid) and rownum=1 order by ctime

论坛徽章:
0
8 [报告]
发表于 2008-08-25 15:41 |只看该作者

回复 #9 crosslife 的帖子

有侮辱过人吗?上面的话对事不对人啊。
写的东西起码要能跑得起来,经得起推敲,否则岂不是误人子弟?
如果想拿分早就不跟帖了。

论坛徽章:
0
9 [报告]
发表于 2008-08-25 15:47 |只看该作者

回复 #10 sunnyfun 的帖子

我只想说我把我能写出来的拿出来交流.LZ也不一定要采纳,这叫误认子弟?难道我的东西跑不起来..我承认我思维不严禁,这和我现在的水平有关系...误人子弟.....
我笑...
看来MYSQL版门槛太高..不适合我们这种新手啊..汗颜...88

论坛徽章:
8
综合交流区版块每周发帖之星
日期:2015-12-02 15:03:53数据库技术版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-09-14 06:20:00金牛座
日期:2014-10-10 11:23:34CU十二周年纪念徽章
日期:2013-10-24 15:41:34酉鸡
日期:2013-10-19 10:17:1315-16赛季CBA联赛之北京
日期:2017-03-06 15:12:44
10 [报告]
发表于 2008-08-25 15:59 |只看该作者
早上来看一下
我没有看懂

现在楼主的描述很清楚了
不过问题已经解决
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP