数据库查询去掉某字段重复项

如有表,我想查询时去掉name的重复项,以id倒序排序,理想查询结果为... 如有表 ,我想查询时去掉name的重复项,以id倒序排序,理想查询结果为 展开
 我来答
马可财经
2013-01-07 · TA获得超过742个赞
知道小有建树答主
回答量:445
采纳率:0%
帮助的人:263万
展开全部
select *, count(distinct name) as ccc from table group by name order by id desc;
查询结果中最终会多出来一个字段ccc,不用这个ccc字段就可以了
使用其他的办法,要么是效率不高,要么是返回不了你想要的结果集。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
baiynijecym
2013-01-07 · TA获得超过1841个赞
知道大有可为答主
回答量:1411
采纳率:66%
帮助的人:1172万
展开全部
可以这样写
select id,name,msg from table1 where id = (select max(id) from table1 b where table1.name = b.name)

select id,name,msg from table1 where not exists(select * from table1 b where table1.name = b.name and table1.id < b.id)
如果要排序的话可以再在后面加order by id desc
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
0460701
2013-01-07 · TA获得超过170个赞
知道答主
回答量:302
采纳率:0%
帮助的人:78.1万
展开全部
SELECT a.* FROM dd a RIGHT JOIN dd b ON a.name=b.name AND a.id != b.id GROUP BY a.`name`
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
随o天
2013-01-07 · TA获得超过3158个赞
知道大有可为答主
回答量:1740
采纳率:71%
帮助的人:2033万
展开全部
SELECT * FROM 表 WHERE id IN (select MAX(id) from 表 GROUP BY name);
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友6458fdab4
2013-01-07 · 超过12用户采纳过TA的回答
知道答主
回答量:74
采纳率:0%
帮助的人:24.9万
展开全部
distinct(字段名)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式