mysql子查询中的any_value与where in失效

问题描述:

在mysql中,执行如下sql语句:

select * from test where id in (select any_value(id) from test group by type);
登录后复制

虽然预期输出每个分组的第一行记录,但结果却返回了整个表。

问题分析:

问题一:

使用any_value函数的子查询会导致where in失效。因为any_value函数返回任意一行匹配记录的值,它不保证返回唯一值,这可能会导致where in比较失败。

问题二:

如果在子查询中省略as id别名,mysql将无法找到select id from ...语句中的id列,因为子查询没有命名其结果列。在这种情况下,mysql会尝试自动生成列名,这可能会导致不确定的行为,例如返回整个表。

解决方案:

问题一:

使用group by和min函数返回每个分组的最小id值,从而确保返回唯一值:

select * from test where id in (select min(id) from test group by type);
登录后复制

问题二:

显式指定子查询结果列的别名:

select * from test where id in (select id from (select any_value(id) as id from test GROUP BY type) as temp);
登录后复制

以上就是MySQL 子查询中 any_value 和 WHERE IN 失效的原因是什么?的详细内容,更多请关注慧达安全导航其它相关文章!

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部