집 >데이터 베이스 >MySQL 튜토리얼 >mysql에 중첩된 쿼리 문이 있습니까?
mysql에는 중첩된 쿼리 문이 있으며 구문은 "SELECT 문 WHERE 조건(SELECT 문)"입니다. 이 문은 하위 쿼리 문이라고도 하며 기존 쿼리 문에서 where 뒤에 다른 쿼리 계층을 중첩할 수 있습니다. . 문, 즉 내부 쿼리 결과가 외부 쿼리에서 참조되는 데이터로 사용됩니다.
이 튜토리얼의 운영 환경: windows10 시스템, mysql8.0.22 버전, Dell G3 컴퓨터.
서브 쿼리라고도 불리는 중첩 쿼리는 실제 작업에서 자주 사용하는 쿼리 방법입니다. 하위 쿼리는 실제로 기존 쿼리 문의 위치 뒤에 중첩된 쿼리 문의 레이어입니다. 즉, 내부 쿼리 결과가 외부 쿼리에서 참조되는 데이터 테이블로 사용됩니다.
작업에서 우리는 비교 연산자(>, >=,
# 创建学员信息表 CREATE TABLE stu_info ( id INT AUTO_INCREMENT PRIMARY KEY, iname VARCHAR(20), gender CHAR(1), department VARCHAR(10), age TINYINT, province VARCHAR(10), email VARCHAR(50), mobilephone CHAR(11) ); # 向学员表中插入数据 INSERT INTO stu_info(iname,gender,department,age,province,email,mobilephone) VALUES ('张勇','男','数学系',23,'河南','sfddf123dd@163.com','13323564321'), ('王兵','男','数学系',25,'江苏','lss1993@163.com','17823774329'), ('刘伟','男','计算机系',21,'江苏','qawsed112@126.com','13834892240'), ('张峰','男','管理系',22,'上海','102945328@qq.com','13923654481'), ('董敏','女','生物系',22,'浙江','82378339@qq.com','13428439022'), ('徐晓红','女','计算机系',24,'浙江','xixiaohong@gmail.com','13720097528'), ('赵伊美','女','数学系',21,'江苏','zhaomeimei@163.com','13417723980'), ('王建国','男','管理系',24,'浙江','9213228402@qq.com','13768329901'), ('刘清','女','统计系',23,'安徽','lq1128@gmail.com','17823651180'), ('赵家和','男','计算机系',28,'山东','dcrzdbjh@163.com','13827811311'); # 创建学员成绩表 CREATE TABLE stu_score( id INT , Excel TINYINT, Tableau TINYINT, MySQL TINYINT ); # 向成绩表中插入数据 INSERT INTO stu_score VALUES (1,87,72,88), (3,90,66,72), (2,90,70,86), (4,88,82,76), (8,92,67,80), (10,88,82,89), (5,79,66,60), (7,91,78,90), (6,82,79,88), (9,85,70,85); # 1.查询年龄超过所有学员平均年龄的学员信息 SELECT * FROM stu_info WHERE age >= avg(age); #需要注意的是Where后面不能使用聚合函数 #应该修改成 SELECT AVG(age) FROM stu_info; SELECT * FROM stu_info WHERE age>=23.3 #二合一 # 1.查询年龄超过所有学员平均年龄的学员信息 SELECT * FROM stu_info WHERE age >= (SELECT AVG(age) FROM stu_info); # 2.查询年龄不低于所属系平均年龄的学员信息 SELECT * FROM stu_info AS s1 WHERE age>= ( SELECT avg(age) FROM stu_info AS s2 WHERE s1.department = s2.department);
비교 연산자와 함께 중첩 쿼리를 사용하는 경우 비교 연산자 뒤의 하위 쿼리는 하나의 결과만 반환할 수 있다는 점에 유의하세요.
(2) ANY 또는 ALL 키워드가 포함된 중첩 쿼리
비교 연산자가 포함된 중첩 쿼리의 경우 쿼리 문의 중첩 부분은 하나의 값만 반환할 수 있습니다. 하위 쿼리가 여러 값을 반환하는 경우 ANY 또는 ALL 키워드를 사용해야 합니다. 일반적으로 ANY/ALL 키워드는 비교 연산자와 함께 사용되는 경우가 많습니다. 다음은 6개의 비교 연산자와 ANY/ALL 키워드의 일치 결과입니다.
# 1.查询非管理系中比管理系任意一个学员年龄小的学员信息 SELECT * FROM stu_info WHERE age <p><img src="https://img.php.cn/upload/article/000/000/067/4324f62c03299e4da154e72d7d28ebb8-1.png" alt="mysql에 중첩된 쿼리 문이 있습니까?"><br> 여기서의 쿼리 논리는 다음과 같습니다. 경영학과 연령(삭제)의 중학생에게 질의하고, 얻은 결과는 22세와 24세이며, 22세 또는 24세 미만인 비경영학과 학생의 정보(즉, 비관리학과의 정보)를 질의한다. -24세 미만의 경영학생). </p><pre class="brush:php;toolbar:false"># 2.查询非管理系中比管理系所有学员年龄大的学员信息 SELECT * FROM stu_info WHERE age > ALL (SELECT DISTINCT age FROM stu_info WHERE department = '管理系') AND department != '管理系';
여기서의 쿼리 로직은 다음과 같습니다. 먼저 경영학과 학생의 나이를 쿼리하고(중복 제거) 얻은 결과는 22와 24입니다. 그런 다음 관리학과가 아닌 학생의 정보를 쿼리합니다. 22세 이상, 24세 이상(즉, 24세 이상 비경영학생을 위한 정보)
(3) IN 키워드가 포함된 중첩 쿼리
쿼리 조건에 알려진 열거 가능한 특정 이산 값이 포함된 경우 IN 키워드를 선택하여 데이터 추출을 완료할 수 있습니다. IN 키워드에는 두 가지 용도가 있습니다.
# 1.查询数学系和计算机系的学员信息 SELECT * FROM stu_info WHERE department IN('数学系','计算机系'); # 2.查询与张勇、刘伟同一个系的学员信息 SELECT * FROM stu_info WHERE department IN (SELECT department FROM stu_info WHERE iname IN('张勇','刘伟')); # 3.查询MySQL成绩大于85分的学员信息 SELECT * FROM stu_info WHERE id IN (SELECT id FROM stu_score WHERE MySQL > 85);
IN 키워드의 중첩 쿼리를 사용할 경우 중첩 부분은 한 필드(예: 위의 부서 필드 또는 ID 필드)의 정보만 반환할 수 있다는 점에 유의하세요. 구문 오류가 발생합니다.
(4) EXISTS 키워드를 포함하는 중첩 쿼리
EXISTS 키워드의 역할은 IN 키워드와 매우 유사합니다. 차이점은 EXISTS 키워드를 사용한 중첩 쿼리는 특정 값 집합을 반환하지 않지만 조건을 충족한다는 것입니다. 논리값(예: True/False). 즉, EXISTS의 기능은 "특정 조건을 만족하는 레코드가 있는지 판단하는 것"인데, 그러한 레코드가 존재하면 True(True)를 반환하고, 해당 레코드가 없으면 False(False)를 반환한다. ).
# 查询MySQL成绩大于85分的学员信息 SELECT * FROM stu_info WHERE EXISTS(SELECT * FROM stu_score WHERE stu_score.id = stu_info.id AND MySQL > 85);
EXISTS 키워드를 사용하는 중첩 문 WHERE와 EXISTS 키워드 사이에는 매개 변수가 없다는 점에 유의해야 합니다. 이는 EXISTS에는 하나의 매개 변수만 필요하며 일반적으로 EXISTS 오른쪽에 하위 쿼리 문을 추가하기 때문입니다. 또한 EXISTS 뒤의 서브 쿼리에서는 EXISTS 뒤의 서브 쿼리에서는 조건을 만족하는 레코드가 있는지 여부에만 관심이 있기 때문에 SELECT 뒤에는 테이블의 모든 필드나 별표 또는 상수를 작성할 수 있습니다. 아래에 반환된 결과는 모두 동일합니다.
[보충] IN 및 EXISTS 두 키워드에 대해 NOT IN 및 NOT EXISTS 두 개의 확장 키워드가 있습니다.
# 查询数学系和计算机系之外的学员信息 # 方法一 SELECT * FROM stu_info WHERE department NOT IN('数学系','计算机系'); #方法二 SELECT * FROM stu_info WHERE NOT EXISTS(SELECT * FROM stu_score WHERE department IN('数学系','计算机系') and stu_score.id = stu_info.id); # not exists的逻辑比较复杂,需要大家慢慢领会 # 主要看not exists括号中的sql语句是否有结果,无结果:才会继续执行where条件;有结果:视为 where条件不成立。 # 当子查询和主查询有关联条件时,相当于从主查询中去掉子查询的数据。
IN 및 EXISTS 두 키워드의 경우 대부분 대체 가능합니다. 가장 큰 차이점은 사용 효율성입니다. 일반적으로 IN보다 EXISTS를 사용하는 것이 더 효율적이지만 구체적인 사용 방법은 실제 상황에 따라 다릅니다. IN은 외부 표면이 크고 내부 테이블이 작은 상황에 적합합니다. ; EXISTS는 외부 표면이 작고 내부 테이블이 작은 상황에 적합합니다.
위에서 우리는 where 문 뒤의 하위 쿼리에 대해서만 배웠습니다. 또한 하위 쿼리는 select 문, from 문 및 had 문 뒤에도 배치될 수 있습니다.
추천 학습: mysql 비디오 튜토리얼
위 내용은 mysql에 중첩된 쿼리 문이 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!