免费注册 查看新帖 |

Chinaunix

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

遇到错误,单行合并多行查询语句 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-07-19 22:15 |只看该作者 |倒序浏览
语句:
SELECT *
FROM `posts`
WHERE `f_id`
IN ( 1, 2, 3 )

查询结束,返回n条记录:
f_id =1 的结果有n多
f_id =2 的结果也有n多
f_id =3 的结果也有n多

这不是我想要的

我想要的结果只有三条:

f_id =1 的结果,只取最后第一条
f_id =2 的结果,只取最后第一条
f_id =3 的结果,只取最后第一条

还有个字段id 可以用来排序,
如何写这些 "order by id desc  limit" 才能输出我想要的结果?

论坛徽章:
0
2 [报告]
发表于 2011-07-20 10:20 |只看该作者
求高人解答

论坛徽章:
0
3 [报告]
发表于 2011-07-20 10:35 |只看该作者
SELECT *
FROM `posts`
WHERE `f_id`
IN ( 1, 2, 3 ) GROUP BY f_id ORDER BY id DESC

你看下是否满足你的要求....

论坛徽章:
0
4 [报告]
发表于 2011-07-20 11:06 |只看该作者
回复 3# eugene_jin


    很好,我测试过了

但有个问题ORDER BY id DESC
这个语句似乎没起作用,无论DESC还是 默认,取出来的三条数据,都不是最后一条,而是最早的一条(取出结果是id号最小,我想要最大的)

论坛徽章:
0
5 [报告]
发表于 2011-07-20 14:37 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
6 [报告]
发表于 2011-07-20 14:38 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
7 [报告]
发表于 2011-07-20 14:53 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP