Sql中联合查询中的”子查询返回的值不止一个“的问题

在子查询中,如果想实现如下的功能:

  select lib,count(*),select sum(newsNo) from Table1 group by lib

  from Tabel1 T1,Table2 T2 where T1.newsNo =T2.newsNo

  group by lib

就会提示“子查询返回的值不止一个。”的错误,意思是子查询不能返回多个结果,只能返回一个结果。

因此可以改用如下的方式:

  select lib,count(*),select sum(newsNo) from Table1 T1 where T1.lib =Table1.lib

  from Tabel1 T1,Table2 T2 where T1.newsNo =T2.newsNo

  group by lib

其中原因还是不太懂,还需要高手指点,可能是跟一个sql语句的执行顺序有关吧

时间: 2024-10-24 16:36:10

Sql中联合查询中的”子查询返回的值不止一个“的问题的相关文章

SQL主、外键,子查询

主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个表只能有一个 PRIMARY KEY 约束,而且 PRIMARY KEY 约束中的列不能接受空值.由于 PRIMARY KEY 约束确保唯一数据,所以经常用来定义标识列. 主键的作用 主键的主要作用如下: (1)保证实体的完整性: (2)加快数据库的操作速度: (3) 在表中添加新记录时,数据库会自

SQL语句面试题目:一般查询和高级子查询

几个表 employees 表: EMPLOYEE_ID              NUMBER(6) FIRST_NAME                VARCHAR2(20) LAST_NAME                 VARCHAR2(25) EMAIL                               VARCHAR2(25) PHONE_NUMBER       VARCHAR2(20) HIRE_DATE                  DATE JOB_ID 

013.子查询和分页子查询(sql实例)

--1 子查询 如果子查询和表连接都实现的时候,推荐用表连接实现( 一般:能用表连接实现的就用表连接,有些情况用表连接不能 或者不易实现的再选择子查询) 系统:缓存,执行计划技术手段 --1 where 条件后 + 子查询 注意: 1 先执行的是子查询语句 2 子查询嵌套的层数越大,性能会随之递减 A) 当子查询写在比较运算符之后(=,!=,>,...)时 要求:子查询的查询结果不能多于1个(1,0(不会报错, 没有结果)) --eg select * from EMP where SAL>(

SQL SERVER技术内幕之4 子查询

最外层查询的结果集会返回给调用者,称为外部查询.内部查询的结果是供外部查询使用的,也称为子查询.子查询可以分成独立子查询和相关子查询两类.独立子查询不依赖于它所属的外部查询,而相关子查询则须依赖它所属的外部查询.子查询的期望值可以是单值的.多值的或以表为值. 1.独立子查询 独立子查询是独立于其外部查询的子查询.在逻辑上,独立子查询在执行外部查询之前只要先执行一次,接着外部查询再使用子查询的结果继续进行查询. 1.1 独立标量子查询 标量子查询是返回单个值的子查询,标量子查询可以出现在外部查询中

Oracle-27-集合操作(交集、并集、差集)&子查询之单行子查询

一.集合操作 1.UNION:并集运算. 语法结构: SQL>select 表1的列1, 表1的列2 from 表1 union select表2的列1, 表2的列2 from表2; 其中表1的列1和表1的列2是来自于表1的两列,表2的列1和表2的列2是来自于表2的两列,需要注意的是,如果union前面是n列,那么后面也必须是n列,即union前后列数必须相同.而且查询结果的列名是按照union前面n列的名称命名(如例1). 2.INTERSECT:交集运算. 语法结构: SQL>select

嵌套子查询和关联子查询

嵌套子查询:  1. 内部查询只处理一次 2. 与null比较,总得到null 3.先进行内部查询,然后再进行外部查询 关联子查询: 1.外部查询得到的每条记录传入到内部查询 2.内部查询基于外部查询传入的值 3.内部查询从其结果中把值传回到外部查询,外部查询使用这些值来完成其处理 什么时候使用? 外部查询返回较少记录时,关联子查询比嵌套子查询效率高; 内部查询返回较少记录时,嵌套子查询比关联子查询效率高. in和exists select * from A where cc in (selec

mysql优化---in型子查询,exists子查询,from 型子查询

in型子查询引出的陷阱:(扫更少的行,不要临时表,不要文件排序就快) 题: 在ecshop商城表中,查询6号栏目的商品, (注,6号是一个大栏目) 最直观的: mysql> select goods_id,cat_id,goods_name from goods where cat_id in (select cat_id from category where parent_id=6); 误区: 给我们的感觉是, 先查到内层的6号栏目的子栏目,如7,8,9,11 然后外层, cat_id in

第五章 复杂查询 5-3 关联子查询

一.普通子查询和关联子查询的区别 在对表中某一部分记录的集合进行比较时,就可以使用关联子查询.在细分的组内进行比较时,需要使用关联子查询. 使用关联子查询是,通常会使用"限定(绑定)"或者"限制"这样的语言. 重点:这里起到关键作用的是在子查询中添加的WHERE子句的条件,该条件指定在同一商品中对各商品的销售单价和平均单价进行比较.注:在使用关联子查询时,需要在表所 对应的列名之前加上表的别名,以"< 表名 >.< 列名 >&quo

mysql---where子查询、form子查询、exists子查询

1.什么是子查询? 当一个查询是另一个查询的条件时,称之为子查询. 2.子查询有什么好处? 子查询可以使用几个简单命令构造功能强大的复合命令. 那么,现在让我们一起来学习子查询. 3.where型的子查询 给它个定义吧:where型的子查询就是把内层查询的结果当作外层查询的条件. 现在,我们来查询文章表里每组主题分类下评论最多的文章. 给定表如下: create table article(article_id int(3),article_title varchar(50),article_c