SQL - 子查询

迄今为止我们所看到的所有SELECT语句都是简单查询,即从单个数据库表中检索数据的单条语句。SQL还允许创建子查询,即嵌套在其他查询中的查询,而且子查询中一般只返回一个字段的数据。

1、利用子查询进行过滤

可以将子查询的结果作为 WHRER 语句的过滤条件:

SELECT *
FROM table1
WHERE col1 IN (SELECT col2
               FROM table2);

分析:在SELECT语句中,子查询总是从内向外处理。在处理上面的SELECT语句时,MySQL实际上执行了两个操作。首先,它执行下面的查询:

SELECT col2
FROM table2

此查询返回一个列的数据。然后,这个列的数据以IN操作符要求的逗号分隔的格式传递给外部查询的WHERE子句。外部查询变成:

SELECT *
FROM table1
WHERE col1 IN (value1, value2, value3...)
  • 在WHERE子句中使用子查询能够编写出功能很强并且很灵活的SQL语句。对于能嵌套的子查询的数目没有限制,不过在实际使用时由于性能的限制,不能嵌套太多的子查询。
  • 在WHERE子句中使用子查询,应该保证SELECT语句具有与WHERE子句中相同数目的列。通常,子查询将返回单个列并且与单个列匹配,但如果需要也可以使用多个列。
  • 虽然子查询一般与IN操作符结合使用,但也可以用于测试等于(=)、不等于(<>)等。

2、作为计算字段使用子查询

使用子查询的另一方法是创建计算字段。

SELECT *,(SELECT count(*)
		 FROM tbl_emp
		 where tbl_emp.deptId = tbl_dept.id) as '人数'
FROM tbl_dept

分析:这条sql查询了全部部门,并且将部门人数从员工表中统计出来。而且子查询为相关子查询,如果我们子查询的WHERE语句中使用了 “WHERE id = id” ,那么就可能会产生歧义,就必须使用完全限定的列名(表名和列名由一个句点分隔)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值