데이터 베이스 MySQL 튜토리얼 MySQL中列子查询与行子查询操作的学习教程_MySQL

MySQL中列子查询与行子查询操作的学习教程_MySQL

May 27, 2016 pm 01:46 PM
m mysql 지도 시간

MySQL 列子查询及 IN、ANY、SOME 和 ALL 操作符的使用
MySQL 列子查询
列子查询是指子查询返回的结果集是 N 行一列,该结果通常来自对表的某个字段查询返回。
一个列子查询的例子如下:

SELECT * FROM article WHERE uid IN(SELECT uid FROM user WHERE status=1)
로그인 후 복사

列子查询中使用 IN、ANY、SOME 和 ALL 操作符

由于列子查询返回的结果集是 N 行一列,因此不能直接使用 = > < >= <= <> 这些比较标量结果的操作符。在列子查询中可以使用 IN、ANY、SOME 和 ALL 操作符:

  • IN:在指定项内,同 IN(项1,项2,…)。
  • ANY:与比较操作符联合使用,表示与子查询返回的任何值比较为 TRUE ,则返回 TRUE 。
  • SOME:ANY 的别名,较少使用。
  • ALL:与比较操作符联合使用,表示与子查询返回的所有值比较都为 TRUE ,则返回 TRUE 。

下面是原始数据表:

table1:

s1
2
10
로그인 후 복사

table2:

s2
5
12
20
로그인 후 복사

ANY 操作符
ANY 关键字必须接在一个比较操作符的后面,表示与子查询返回的任何值比较为 TRUE ,则返回 TRUE 。一个 ANY 例子如下:
SELECT s1 FROM table1 WHERE s1 > ANY (SELECT s2 FROM table2)
查询返回结果如下所示:

s1
10
로그인 후 복사

在子查询中,返回的是 table2 的所有 s2 列结果(5,12,20),然后将 table1 中的 s1 的值与之进行比较,只要大于 s2 的任何值即表示为 TRUE,符合查询条件。
IN 是 = ANY 的别名,二者相同,但 NOT IN 的别名却不是 <> ANY 而是 <> SOME。
特殊情况
如果 table2 为空表,则 ANY 后的结果为 FALSE;
如果子查询返回如 (NULL,NULL,NULL) 列为空的结果,则 ANY 后的结果为 UNKNOWN 。
ALL 操作符
ALL 关键字必须接在一个比较操作符的后面,表示与子查询返回的所有值比较为 TRUE ,则返回 TRUE 。一个 ALL 例子如下:
SELECT s1 FROM table1 WHERE s1 > ALL (SELECT s2 FROM table2)
该查询不会返回任何结果,因为 s1 中没有比 s2 所有值都大的值。
当然在该例子查询中,返回了 s2 的所有值,您可以在该子查询中添加任何条件以限制返回的查询结果而无需全部返回。
NOT IN 是 <> ALL 的别名,二者相同。
特殊情况
如果 table2 为空表,则 ALL 后的结果为 TRUE;
如果子查询返回如 (0,NULL,1) 这种尽管 s1 比返回结果都大,但有空行的结果,则 ALL 后的结果为 UNKNOWN 。
注意:对于 table2 空表的情况,下面的语句均返回 NULL:

SELECT s1 FROM table1 WHERE s1 > (SELECT s2 FROM table2)
SELECT s1 FROM table1 WHERE s1 > ALL (SELECT MAX(s1) FROM table2)
로그인 후 복사

MySQL 行子查询
行子查询是指子查询返回的结果集是一行 N 列,该子查询的结果通常是对表的某行数据进行查询而返回的结果集。
一个行子查询的例子如下:

SELECT * FROM table1 WHERE (1,2) = (SELECT column1, column2 FROM table2)
로그인 후 복사

在该例子中,在保证子查询返回单一行数据的前提下,如果 column1=1 且 column2=2 ,则该查询结果为 TRUE。
MySQL 行构造符
在上面的例子中,WHERE 后面的 (1,2) 被称为行构造符,也可以写作 ROW(1,2)。行构造符通常用于与对能返回两个或两个以上列的子查询进行比较。
MySQL 行子查询实例
下面是用于例子的两张原始数据表:
article 表:

20151216173312137.png (646×131)

blog 表:

20151216173333001.png (645×102)

SQL 如下:

SELECT * FROM article WHERE (title,content,uid) = (SELECT title,content,uid FROM blog WHERE bid=2)
로그인 후 복사

查询返回结果如下所示:

20151216173412781.png (659×53)

在该行子查询例子中,将 article 表 title,content,uid 字段逐一与子查询返回的行记录作比较,如果相等则列出这些相等的记录(理论上可能不止一条)。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 Dec 09, 2024 am 11:42 AM

MySQL 8.4(2024년 최신 LTS 릴리스)에 도입된 주요 변경 사항 중 하나는 &quot;MySQL 기본 비밀번호&quot; 플러그인이 더 이상 기본적으로 활성화되지 않는다는 것입니다. 또한 MySQL 9.0에서는 이 플러그인을 완전히 제거합니다. 이 변경 사항은 PHP 및 기타 앱에 영향을 미칩니다.

PHP가 MySQL에 연결된 후 페이지가 비어 있습니다. 유효하지 않은 다이 () 함수의 이유는 무엇입니까? PHP가 MySQL에 연결된 후 페이지가 비어 있습니다. 유효하지 않은 다이 () 함수의 이유는 무엇입니까? Apr 01, 2025 pm 03:03 PM

PHP가 MySQL에 연결 한 후 페이지가 비어 있고 Die () 함수가 실패한 이유가 있습니다. PHP와 MySQL 데이터베이스 간의 연결을 배울 때는 종종 혼란스러운 것들이 발생합니다 ...

동전을 바이 니스로 옮기는 방법? HTX의 Binance 플랫폼에 대한 암호화 자산을 언급하는 방법은 무엇입니까? 동전을 바이 니스로 옮기는 방법? HTX의 Binance 플랫폼에 대한 암호화 자산을 언급하는 방법은 무엇입니까? Mar 03, 2025 pm 08:51 PM

Huobi to Binance Transfer Guide : 안전하고 편리하게 Crypto 자산을 양도하여 많은 투자자들이 Huobi와 Binance를 동시에 사용합니다. 이 기사에서는 트럼프 및 USDT와 같은 HUOBI (HTX)의 암호화 자산을 Binance 플랫폼으로 안전하게 전송하는 방법을 안내합니다. Binance는 높은 보안, 풍부한 통화 및 거래 쌍 및 세계 최고의 거래량으로 인기가 있습니다. Binance Exchange의 장점 : 전 세계 시장의 50%를 차지하는 세계 최고의 거래량은 주로 Bitcoin, Ethereum 및 USDT와 같은 주류 스타블 레코 인이며 현재 가장 안정되고 안정적인 교환 중 하나입니다. 이 튜토리얼은 Trump와 USDT를 예로들 것입니다

램프 아키텍처에서 Node.js 또는 Python 서비스를 효율적으로 통합하는 방법은 무엇입니까? 램프 아키텍처에서 Node.js 또는 Python 서비스를 효율적으로 통합하는 방법은 무엇입니까? Apr 01, 2025 pm 02:48 PM

많은 웹 사이트 개발자는 램프 아키텍처에서 Node.js 또는 Python 서비스를 통합하는 문제에 직면 해 있습니다. 기존 램프 (Linux Apache MySQL PHP) 아키텍처 웹 사이트 요구 사항 ...

PC 및 모바일 측면에서 동일한 페이지를 공유하고 캐시 문제를 처리하는 방법은 무엇입니까? PC 및 모바일 측면에서 동일한 페이지를 공유하고 캐시 문제를 처리하는 방법은 무엇입니까? Apr 01, 2025 pm 01:57 PM

PC 및 모바일 측면에서 동일한 페이지를 공유하고 캐시 문제를 처리하는 방법은 무엇입니까? Baota 배경, PC 측면을 만드는 방법 및 ...

Binance C2C는 무엇입니까? 위험은 무엇입니까? 안전합니까? Binance C2C 코인 동전 튜토리얼 구매 및 판매 Binance C2C는 무엇입니까? 위험은 무엇입니까? 안전합니까? Binance C2C 코인 동전 튜토리얼 구매 및 판매 Mar 05, 2025 pm 04:48 PM

Binance C2C Trading Guide : Cryptocurrency에 돈을 입금하고 인출하는 안전하고 편리한 방법은 Binance C2C (Customertocustomer) 거래 모델을 자세히 설명하고 보안, 특성 및 운영 절차를 설명하며 Binance C2C 예금 및 돈을 쉽게 마스터 할 수 있도록 그래픽 자습서를 제공합니다. Binance C2C는 무엇입니까? Binance C2C는 Binance 플랫폼에서 제공하는 사용자 간 암호 화폐 거래 서비스로서 사용자에게 편리한 cryptocurrency 및 Fiat Currency Exchange 채널을 제공합니다. 2019 년에 출시 된이 서비스는 피어 투 피어 거래 모델을 통해 여러 암호 화폐 및 화폐 통화 거래를 지원하며 향상된 보안 및 여러 기능을 제공합니다. Binance C2C 플랫폼은 전통적인 OTC 거래와 비교하여 두 당사자를 거래에 인증하고 완전한 지원을 제공합니다.

거래 공제 잔액과 결합 된 PHP 낙관적 잠금 실패 : 동시성 상황에서 잔액이 올바르게 공제되는지 확인하는 방법은 무엇입니까? 거래 공제 잔액과 결합 된 PHP 낙관적 잠금 실패 : 동시성 상황에서 잔액이 올바르게 공제되는지 확인하는 방법은 무엇입니까? Mar 31, 2025 pm 11:42 PM

이 기사에서 PHP 낙관적 잠금 및 거래와 함께 균형을 공제하는 문제에 대한 자세한 설명은 PHP, 낙관적 잠금 및 데이터베이스 트랜잭션을 사용한 균형 공제를 자세히 분석합니다.

See all articles