免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: jackywdx
打印 上一主题 下一主题

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

论坛徽章:
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 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-08-25 12:20 |显示全部楼层

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

论坛徽章:
0
3 [报告]
发表于 2008-08-25 14:51 |显示全部楼层

回复 #2 crosslife 的帖子

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

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

论坛徽章:
0
4 [报告]
发表于 2008-08-25 16:34 |显示全部楼层
我测试过2楼的语句,确实可以执行,而且取得出数据,由于比较忙,现在也没有怎么仔细检查。不过我也感觉要取出要求的记录没有那么简单。这是我结贴结得比较匆促。
不过只要是回贴的我已经很感谢了,就算不对也没有权利去说什么。。。
对于问题的探讨希望大家可以踊跃,只是希望对题论事。

论坛徽章:
0
5 [报告]
发表于 2008-08-25 16:37 |显示全部楼层
原帖由 crosslife 于 2008-8-25 15:47 发表
我只想说我把我能写出来的拿出来交流.LZ也不一定要采纳,这叫误认子弟?难道我的东西跑不起来..我承认我思维不严禁,这和我现在的水平有关系...误人子弟.....
我笑...
看来MYSQL版门槛太高..不适合我们这种新手啊 ...

希望不要太在意哈,大家都是互相交流学习的,没有说答错了就要怎么怎么样的。
回贴已经是一种美德了,呵呵。

论坛徽章:
0
6 [报告]
发表于 2008-08-25 16:45 |显示全部楼层
原帖由 sunnyfun 于 2008-8-25 15:24 发表



我要想一次得到所有的,我是这么写的:

SELECT DISTINCT
CASE WHEN a.ctime > b.ctime
THEN a.suid_FK
ELSE b.suid_FK
...


有一位高人也告诉我是这么写的,我想问一下这几个case when的东西能不能合并在一起,为什么要分成三次讨论。写成一个case when
SELECT DISTINCT
CASE WHEN a.ctime > b.ctime
THEN a.suid_FK,a.tuid_FK,a.ctime
ELSE b.suid_FK,b.tuid_FK,b.ctime
END from ....这样可否。
另外,这种语句性能好像有点低,我的表里面有2万多条记录,执行一次差不多花了将近1.8s。不过这是在我的虚拟机上运行的。
不知道有没有好一点的方案。

论坛徽章:
0
7 [报告]
发表于 2008-08-27 09:49 |显示全部楼层
原帖由 sunnyfun 于 2008-8-26 10:01 发表
这么写好不好使运行了试试就知道了。

PS:
crosslife 给的是 Oracle 的语法,在mysql下是跑不了的,至少我这里是。

楼主竟然说可以执行,令人生疑,难不成两个人都跑错版了?


测试过,crosslife的语句可以执行,版本: 5.1.26-rc
问题已经解决,谢谢各位。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP