⑴ sql 子查询
所谓 SQL 子查询就是嵌套在其他查询中的查询。子查询通常用于 WHERE 子句的 IN 操作符中进行过滤,以及用来填充计算列。下面我们从这两种使用场景展开学习。
本节涉及到关系表如下:
最上方的订单表 Orders 存储了订单 ID 、订单日期以及顾客 ID ;具体的订单信息存储在 OrderItems 表中,通过 order_num 进行关联;具体的顾客信息存储在顾客表 Customers 中,通过 cust_id 字段进行关联。
下面,假设我们需要检索出购买了 RGA01 产品的所有顾客信息,应该怎么做呢?
首先,我们只列出步骤:
接下来,我们来完成第一步:
包含了产品 RGAN01 的订单编号:
有了订单编号,就可以从订单表检索出顾客 ID 了:
运行结果:
接下来,我们来合并上面的两步:把第一个查询变为子查询,放在 WHERE 语句的 IN 操作符之后:
运行结果和上述第二步获得的结果是一样的:
在 SELECT 语句中子查询从内向外处理:首先执行 SELECT order_num FROM OrderItems WHERE prod_id = 'RGAN01' 子查询,将返回的订单号作为 IN 操作符的参数,执行外部查询: SELECT cust_id FROM Orders WHERE order_num IN ( 20007, 20008 ); 。
最后,我们来看第三步,根据顾客 ID 检索出顾客相关信息。
运行结果:
同理,我们可以将上述的 WHERE 子句替换为子查询:
至此,我们的检索任务就完成了:查询购买了 RGAN01 商品的所有顾客姓名及联系方式。
子查询的另一个使用场景为创建计算字段。同样,我们以一个案例来学习:检索每个顾客的订单的总数。
顾客表与订单表是一对多的关系,即一个顾客对应多个订单,但一个订单只对应一个顾客。
如下的 SQL 检索出顾客 1000000001 的订单数:
要对每个顾客的订单计数,应该将其作为子查询:
运行结果:
上述 SQL 对 Customers 表中每个顾客返回三列: cust_name cust_state 和 orders 。其中 orders 为子查询创建的计算字段,该子查询对检索出的每个顾客都执行一次,一共执行了 6 次子查询。
在子查询的条件中,我们使用了表的完全限定列名 Orders.cust_id = Customers.cust_id ,这是因为 Orders 表和 Customers 表中包含了字段名名称相同的列。
本节我们学习了在 SELECT 语句中使用子查询的两种用法:将子查询应用于 WHERE 子句的 IN 操作符中,进行条件过滤,以及用子查询创建计算字段。
子查询的检索效率不够理想,下一篇文章中小鱼将和大家展开联结表的学习~ 连接表 是数据检索的精华和重点,我们拭目以待吧!
⑵ mysql 分组子查询sql怎么写
一使用SELECT子句进行多表查询
SELECT 字段名 FROM 表1,表2 … WHERE 表1.字段 = 表2.字段 AND 其它查询条件
SELECT a.id,a.name,a.address,a.date,b.math,b.english,b.chinese FROM tb_demo065_tel AS b,tb_demo065 AS a WHERE a.id=b.id
注:在上面的的代码中,以两张表的id字段信息相同作为条件建立两表关联,但在实际开发中不应该这样使用,最好用主外键约束来实现
二使用表的别名进行多表查询
如:SELECT
a.id,a.name,a.address,b.math,b.english,b.chinese FROM tb_demo065
a,tb_demo065_tel b WHERE a.id=b.id AND b.id='$_POST[textid]'
SQL语言中,可以通过两种方式为表指定别名
MySQL是一个关系型数据库管理系统,由瑞典MySQL
AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的
RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。
MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。
由于其社区版的性能卓越,搭配 PHP 和 Apache 可组成良好的开发环境。
⑶ sql 分组子查询怎么写
你的意思是不是“找出所有status字段不是OK的BarCode,然后显示找到的这些BarCode对应的所有的记录”
比如:某个BarCode有三条记录,这三条记录中有一条status不是OK,那么就显示这三条记录;另一个BarCode有亮条记录,他们的status状态都是OK,那么就不显示。是这个意思不是。
如果是那么不需要分组,直接子查询就可以。
子查询的内容是查询status!='OK'(因为不知道是不是只有NG一种不OK的状态所以用了“不等于”,具体的要根据业务情况来定)的BarCode。
外层就是利用子查询查到的BarCode去查询就可以了,可以直接用in或者exist都可以。
比如某个编号为1111的有三条数据,其中有一条的status不是ok,那么子查询就会找到这条不是ok的记录,并返回编号1111,外层查询在利用编号1111,查到全部的三条记录。
⑷ 一文讲懂SQL子查询
大家好,我是宁一。
今天讲解SQL教程第18课:子查询。
SQL语句可以嵌套,最常见的就是查询语句的嵌套。
基本语法:
我们一般称外面嵌套的语句为主查询,里面被嵌套的语句为子查询,有时也会叫外查询、内查询,大家知道意思就好。
子查询要用括号括起来。子查询不仅可以放在WHERE的后面,还可以放在SELECT、FROM的后面,我们一个个来讲解。
1、子查询+WHERE子句
SQL执行时,会先执行括号内的子查询,子查询最常与WHERE子句结合使用。子查询的结果作为WHERE子句的筛选条件,完成更复杂的数据检索。
实例: 在Students表中,找出所有在"宁一"后面出生的学生。
实例解析: 需要先确定"宁一"的生日,再将生日作为WHERE筛选条件,得到最终数据。
第一步:找到"宁一"的生日
第二步:将生日作为WHERE筛选条件,得到最终数据,子查询语句要用括号括起来。
SELECT语句的子查询经常与聚合函数结合使用。因为我们使用聚合函数的时候,记录会合成一条,其它数据细节就不能显示了。
比如: 我们想要查看学生表中所有的学生姓名、学生生日、学生的最大生日。
示例结果:
错误写法:
像上面这样写是会报错的,因为聚合函数与其他表中的列(Sname,Sage),同时放在SELECT的后面。需要用GROUP BY语句将这些表中的列(Sname,Sage)分组。
上面的语句后面加上 GROUP BY Sname,Sage 就可以了。
但是这样写,会将每组的数据聚合成1条数据,比如每组有3条数据,使用聚合函数MAX()+GROUP BY,最终每组只会显示1条最大值的数据。
我们需要展现Students表中所有的学生,这样写不能满足我们的需求。
正确写法: 结合子查询来实现。
子查询与FROM子句结合使用,子查询结果被当成了一个“表”,可以用SELECT语句做进一步的筛查。
比如:我们先写一个SELECT查询语句
将上面的查询语句放在FROM的后面,则上面查询到的结果,就会被当成一个“表”。
这里有一个特别要注意的地方,放在FROM后面的子查询,必须要加别名。
复杂的子查询再嵌套进 FROM 里会让整个查询看起来过于复杂,我们一般会将子查询结果储存为视图,然后再直接使用视图作为来源表,视图会SQL高阶课程中详细讲解。
其实子查询就是查询语句嵌套,没有什么新的东西,只是多了一个层级,由内向外地一层层梳理就会很清楚了。
作业: 结合Students表,从Teachers表中找出当班主任的老师(通过子查询实现)。
作业解析: 先从Students表中,找出所有班主任的Tid并去重,将查询结果作为筛选条件,放在WHERE语句中。
⑸ sql 子查询
1、二楼提供的sql我查询出来的结果如下。
mysql> select student.stuNo,stuName,stuAge,Score
-> from student,stuMark
-> where student.stuNo in (
-> select stuMark.stuNo
-> from stuMark);
+-------+---------+--------+-------+
| stuNo | stuName | stuAge | Score |
+-------+---------+--------+-------+
| 1 | 张三 | 19 | 99 |
| 1 | 张三 | 19 | 96 |
| 2 | 李四 | 20 | 99 |
| 2 | 李四 | 20 | 96 |
+-------+---------+--------+-------+
2、我提供两个sql语句。供楼主参考。
mysql> select * from student,stumark where student.stuno=stumark.stuno;
+-------+---------+--------+-------+--------+-------+
| stuNo | stuName | stuAge | stuNo | course | Score |
+-------+---------+--------+-------+--------+-------+
| 1 | 张三 | 19 | 1 | java | 99 |
| 2 | 李四 | 20 | 2 | C# | 96 |
+-------+---------+--------+-------+--------+-------+
mysql> select *from student ta,stumark tb where ta.stuno in(select stuno from s
tumark) and ta.stuno=tb.stuno;
+-------+---------+--------+-------+--------+-------+
| stuNo | stuName | stuAge | stuNo | course | Score |
+-------+---------+--------+-------+--------+-------+
| 1 | 张三 | 19 | 1 | java | 99 |
| 2 | 李四 | 20 | 2 | C# | 96 |
+-------+---------+--------+-------+--------+-------+
2 rows in set (0.00 sec)
就是上面的那两个。我不明白楼主为什么一定要子查询。这个完全没有必要要。我感觉我第一种方法还行。
下面我再附上这两个表在mysql下创建的语句。供大家参考:
student表
# MySQL-Front 3.2 (Build 6.2)
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET CHARACTER SET 'latin1' */;
# Host: localhost Database: test
# ------------------------------------------------------
# Server version 5.0.18-nt
DROP DATABASE IF EXISTS `test`;
CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET latin1 */;
USE `test`;
#
# Table structure for table student
#
CREATE TABLE `student` (
`stuNo` int(11) NOT NULL auto_increment,
`stuName` varchar(11) default NULL,
`stuAge` int(11) default NULL,
PRIMARY KEY (`stuNo`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
#
# Dumping data for table student
#
INSERT INTO `student` (`stuNo`,`stuName`,`stuAge`) VALUES (1,'张三',19);
INSERT INTO `student` (`stuNo`,`stuName`,`stuAge`) VALUES (2,'李四',20);
INSERT INTO `student` (`stuNo`,`stuName`,`stuAge`) VALUES (3,'王武',23);
INSERT INTO `student` (`stuNo`,`stuName`,`stuAge`) VALUES (4,'赵六',33);
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
stumark表:
# MySQL-Front 3.2 (Build 6.2)
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET CHARACTER SET 'latin1' */;
# Host: localhost Database: test
# ------------------------------------------------------
# Server version 5.0.18-nt
DROP DATABASE IF EXISTS `test`;
CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET latin1 */;
USE `test`;
#
# Table structure for table stumark
#
CREATE TABLE `stumark` (
`stuNo` int(11) NOT NULL default '0',
`course` varchar(11) default NULL,
`Score` int(11) default NULL,
PRIMARY KEY (`stuNo`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
#
# Dumping data for table stumark
#
INSERT INTO `stumark` (`stuNo`,`course`,`Score`) VALUES (1,'java',99);
INSERT INTO `stumark` (`stuNo`,`course`,`Score`) VALUES (2,'C#',96);
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
希望我的回答能对你有帮助
⑹ SQL子查询代码如何写
select from 用户信息表 where 用户名 in(
select 用户名 from 订单表 group by 用户名 having sum( 订单额 ) <1000 )
and 性别=‘男‘
⑺ sql子查询如何使用主查询里的字段作为筛选条件
sql子查询使用主查询里的字段作为筛选条件的方法:
使用SELECT子句、GROUP BY子句、HAVING子句、ORDER BY子句中均可使用子查询语句,较常用的是WHERE子句、HAVING子句和FROM子句。
子查询是在一个完整的查询语句中,嵌套不同功能的小查询,从而完成复杂查询的一种编写形式。本部分主要介绍非关联子查询,关联子查询的适用场景,语句写法,执行逻辑及相对应的注意事项。
⑻ SQL里面的嵌套查询语句怎么写
就是在SELECT-FROM-WHERE查询块中插入另一个查询块就行了
举个例子:
SELECT S#,SNAME FROM S WHERE S# IN
SELECT S# FROM SC WHERE C# IN
SELECT C# FROM C WHERE CNAME='Y';
注意比单个SELECT语句多了“IN”
⑼ sql 子查询如何写
select id from 表A
full join
(select id,count(id) from 表B group by id)
on A.id=B.id