sql语句单行子查询返回多个行的问题

我有一张sc表,如下图为什么我执行这一句不报错:select(selectgradefromscwheresc.sno=t.snoandcno='c001')as数据库f... 我有一张sc表,如下图为什么我执行这一句不报错:select (select grade from sc where sc.sno=t.sno and cno='c001') as 数据库 from sc t;而执行下面这句就报单行子查询返回多个行的错:select (select grade from sc where sc.sno=t.sno) as 数据库 from sc t; 展开
 我来答
唐城冬
2019-07-07 · 大家一起学习进步吧!!!
唐城冬
采纳数:915 获赞数:1815

向TA提问 私信TA
展开全部
很明显啊,说明你的sno不是主键,数据不是唯一的
如果是sql server这样写
select (select top 1 grade from sc where sc.sno=t.sno) as 数据库 from sc t;
oracle这样写
select (select grade from sc where sc.sno=t.sno and rownum=1) as 数据库 from sc t;
fuyh16
2019-07-07 · TA获得超过222个赞
知道小有建树答主
回答量:462
采纳率:82%
帮助的人:119万
展开全部
首先看你的数据,就一张表,不知道你为什么要自己跟自己关联进行查询,明明可以一次查出来,非得多关联一次。
select grade from sc where cno='c001'
这样就搞定了。
然后说说返回多行的问题,因为第二次执行的时候,没有限制cno等于c001,导致把所有cno的列多查出来了,所以返回多行,而第一次执行,至返回一条cno为c001的数据。
给你个建议,估计你是把项目中的一段代码粘贴出来了,原来的代码中,可能有其他关联条件或者逻辑算法,导致你非得sc表和sc表进行了一次关联,尽量不要用这种关联,如果数据量很大,这样两个大表关联查询,会很慢,性能肯定低。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
椰风挡不住QwQ
2019-07-06
知道答主
回答量:12
采纳率:0%
帮助的人:2.4万
展开全部
看数据,那可不就返回多行了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式