多语言展示
当前在线:1959今日阅读:27今日分享:41

MySQL基础三种类型的子查询

为了给主查询(外部查询)提供数据而首先执行的查询(内部查询)被叫做子查询。一般根据子查询的嵌入位置分为,where型子查询,from型子查询,exists型子查询。
方法/步骤
1

1、where型子查询where型子查询即把内层sql语句查询的结果作为外层sql查询的条件.    子查询要包含在括号内。    建议将子查询放在比较条件的右侧。    单行操作符对应单行子查询,多行操作符对应多行子查询。n  单行操作符  右边子查询必须返回的是单个值,单行比较运算符(=,>,>=,<,<=,<>)n  多行操作符 右边子查询可以返回多行,但必须是单列,ALL, ANY,IN 其中,ALL和ANY运算符必须与单行比较运算符(=,>,>=,<,<=,<>)结合使用

2

2、from型子查询from型子查询即把内层sql语句查询的结果作为临时表供外层sql语句再次查询.

3

3、exists型子查询

4

4、复制表子查询(1)复制表(1)拷贝表结构CREATE TABLE newadmin LIKE admin;(2)拷贝表结构和数据(但约束与索引除外)CREATE TABLE newadmin  AS   ( SELECT *  FROM admin  )  ;(3)拷贝表结构+数据CREATE TABLE newadmin LIKE admin;  INSERT INTO newadmin SELECT * FROM admin;(4)跨数据库拷贝表CREATE TABLE newadmin LIKE shop.admin;  CREATE TABLE newshop.newadmin LIKE shop.admin;(5)拷贝一个表中其中的一些字段(指定新名),其中一些数据CREATE TABLE newadmin AS  (  SELECT id, username AS uname, password AS pass FROM admin  WHERE id<10)  ;(6)在创建表的同时定义表中的字段信息。create table tt(         eid int primary key auto_increment)as(         select employee_id as eid,first_name,last_name,email from employees);

5

(2)复制数据在 INSERT 语句中加入子查询。不必书写 VALUES 子句。子查询中的值列表应与 INSERT 子句中的列名对应。INSERT INTO emp2SELECT * FROM employees WHERE department_id = 90;或INSERT INTO sales_reps(id, name, salary, commission_pct)SELECT employee_id, last_name, salary, commission_pctFROM   employeesWHERE  job_id LIKE '%REP%';

推荐信息