mysql in 查询, 里面的每个条件都指定返回条数,能否实现,怎么写?

mysql in 查询, 里面的每个条件都指定返回条数,能否实现,怎么写?

SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1,value2)

table_name 里面包含value1和value2的值有很多条,能否指定返回条数。

类似:

select * from table_name where column_name = value1 limit 5;
select * from table_name where column_name = value2 limit 5;

或有其他方法实现这个查询?

阅读 5.8k
2 个回答

就是or/in/union all的转换,性能也是union all比较好,也能满足你所说的返回指定条数。

(select * from table_name where column_name = value1 limit 5)
union all
(select * from table_name where column_name = value2 limit 5);

你这个sql与你的描述好像并不一致
SELECT column_name(s),count(column_name(s))
FROM table_name
WHERE column_name(s) IN (value1,value2,...)
group by column_name(s)

这种写法逻辑上是没什么问题,但写完之后还请看看执行计划,我如果记得不错的话,mysql的in的效率并不高,如果是单张表的话,我也没想出来什么好主意

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题