查询多值不去掉重复

2020-03-06 13:07:03 +08:00
 lcxz

id key val

1 1 10

2 2 20

...

8 8 80

select * from a where key in(1,2,1,5,2,8)

查询结果:1,2,5,8 记录

但我想要:1,2,1,5,2,8 记录

2480 次点击
所在节点    MySQL
3 条回复
opengps
2020-03-06 13:27:03 +08:00
同一个表,union 5 次得出这 6 个结果
这类行重复需求尽量放到业务层用程序处理,数据库尽可能只执行最简单的逻辑
Sasasu
2020-03-06 14:01:23 +08:00
首先你不该用 IN,没有一个数据库喜欢。

应该用 join on A.id = B.id
af463419014
2020-03-06 14:03:06 +08:00
你是 PM 派过来的奸细吗,为什么要跟 PM 一样提这种反人类的需求

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/650369

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX