MySQL 数据库中的子查询:
子查询: 在一条 select 查询语句中嵌套另一条 select 语句, 其主要作用是充当查询条件或确定数据源.
代码案例如下:
例 1. 查询大于平均年龄的学生:
select * from students where age> (select avg(age) from students);
例 2. 查询学生在班的所有班级名字:
select name from classes where id in (select cls_id from students where cls_id is not null);
例 3. 查找年龄最大, 身高最高的学生:
select * from students where (age, height) = (select max(age), max(height) from students);
MySQL 的高级应用:
1. 将查询出来的数据添加到一个新的表中:
使用子查询将查询后的结果作为数据插入到新的表中, 通过关键字 create table ... select ... 实现, 代码实现:
create table 表名 (字段名 1, 类型 约束,...) select 字段名 from 表名 where 查询条件
其执行流程是, 先执行 select 语句通过 where 条件确定数据源, 然后再将查询出来的数据插入到新创建的表中.
注意: 在使用此方法时, 要想给表中的指定字段添加数据, 那么需要将查找出来的字段起一个和表中字段名相同的别名.
2. 将查询的结果添加到表中:
使用子查询将查询后的结果作为数据插入到表中, 通过关键字 insert into ... select ... 实现, 代码实现:
insert into 表名 (字段名 1,...) select 字段名 1,.. from 表名 where 查询条件
其执行流程是, 先执行 select 语句, 将指定的数据通过 where 条件筛选出来, 然后再执行 insert into 语句给指定的字段名进行数据的添加.
3. 使用连接更新表中的某个字段的数据:
使用连接更新表中的字段数据, 通过关键字 update ... join.. 关键字实现, 代码实现:
update 表 1 join 表 2 on 表 1. 字段 = 表 2. 字段 set 表 1. 字段 = 表 2. 字段
其执行流程是将两个表连接后, 把表 2 中的字段的值设置给表 1 中的指定字段.
来源: http://www.bubuko.com/infodetail-3333187.html