56,677
社区成员
发帖
与我相关
我的任务
分享
一个很蛋疼的问题,如下,最后的结果查询不来,非常让人疑惑。
使用过程随机生成数据,我怀疑时类型问题,但是在创建中使用了cast和concat都没用,直接用in (98,91)之类的可以,但是用上子查询就查不出来 了
create table query_test(
stu_id varchar(20) primary key comment "学号",
stu_name varchar(20) comment "姓名",
stu_grade int comment "成绩"
)
delimiter $$
create procedure auto_insert1()
begin
declare i int default 1;
while (i<1000) do
insert into worker.query_test values (i,substr(md5(rand()*100),1,3),rand()*100);
set i=i+1;
end while;
end $$
delimiter ;
call auto_insert1();
select * from query_test where stu_id in
(select group_concat(stu_id) from query_test group by stu_grade having stu_grade =100)
子查询语句本身有问题,里面的group by 用得不对,查询结果里用到了stu_id,这不在group by 分组字段里