子查询

在開始了解子查询之前,首先做下准备工作,建立3个表,

准备工作

1、建表

建customers表的命令例如以下,其他的表与之相似:

create table customers(cust_name varchar(10),cust_id int(10),cust_tel varchar(10));

2、插入内容

为customers表插入内容的命令例如以下,其他的与子相似:

insert into customers values('wu',2,'1387234');

最后三个表的内容截图例如以下:

《MySQL必知必会学习笔记》:子查询-LMLPHP

《MySQL必知必会学习笔记》:子查询-LMLPHP

《MySQL必知必会学习笔记》:子查询-LMLPHP

子查询

前面我们所学的东西都是简单的查询,即从单个数据库表中检索数据的单条语句。

究竟什么是子查询呢?通过以下这个样例,相信我们就更好的理解了。

上面我们建了三个表,分别为customers/orders/ordersitems.

如今,假如,我们想看下订购了物品 apple的全部客户信息,应该如何检索呢?

以下列出详细的步骤:

如今我们依照步骤来查询下,观察下结果:

《MySQL必知必会学习笔记》:子查询-LMLPHP

从上面能够看出,我们就是依照步骤,将第一步的结果当做第二步的条件来进行查询。将第二步的结果直接作为第三步的条件来进行查询,最后得到终于的结果。

如今,我们分别把第一个子查询(返回订单号的那一个)变为子查询组合到第二个查询中。

第一个查询的代码例如以下:

select order_id from ordersitems where content='apple';

作为子查询组合到第二个查询后的代码例如以下:

select cust_id from orders where order_id in (
select order_id from ordersitems where content='apple'
);

结果例如以下,从结果能够看出。与我们单个查询的结果是一致的:

《MySQL必知必会学习笔记》:子查询-LMLPHP

如今。我们就把上面的查询作为子查询组合到第三个查询中。代码例如以下:

select cust_name,cust_tel from customers where cust_id in(
select cust_id from orders where order_id in(
select order_id from ordersitems where content='apple')
)
);

注意:包含子查询的select语句难以阅读和调试。特别是他们较为复杂时。如上所看到的把子查询分解为多行而且适当地进行缩进,能极大地简化子查询的使用。

《MySQL必知必会学习笔记》:子查询-LMLPHP

在where子句中使用子查询能够编写出功能非常强而且非常灵活的SQL语句。对于能嵌套的子查询的数目没有限制,只是在实际使用时因为性能的限制,不能嵌套太多的子查询。

注意:在子查询中。列必须匹配

作为计算字段使用子查询

上面介绍的都是作为条件使用子查询。以下就介绍下作为计算字段使用子查询。

还是以一个样例来进行说明。

假如须要显示customers表中每一个客户的订单总数。

为运行这个操作,过程例如以下:

比如:查询客户id=1的订单数的命令例如以下:

select count(*) as order_total from orders where cust_id=1;

《MySQL必知必会学习笔记》:子查询-LMLPHP

将上面的命令作为字段的子查询的代码例如以下:

select cust_name,cust_tel,(select count(*) from orders where orders.cust_id==customers.cust_id) from customers ;

《MySQL必知必会学习笔记》:子查询-LMLPHP

小结

子查询能够理解为嵌套,这里方便理解一点。可是在我们使用子查询的过程中。要先分步骤来完毕,然后将子查询一个一个的组合起来,直到这个子查询增加之后得到的结果是符合要求的。然后继续将下一个子查询组合进行直至完毕全部的子查询都全部正确的增加。

05-11 09:37
查看更多