在MySQL中使用子查詢和標(biāo)量子查詢的基本操作教程
MySQL 子查詢
子查詢是將一個 SELECT 語句的查詢結(jié)果作為中間結(jié)果,供另一個 SQL 語句調(diào)用。MySQL 支持 SQL 標(biāo)準(zhǔn)要求的所有子查詢格式和操作,也擴(kuò)展了特有的幾種特性。
子查詢沒有固定的語法,一個子查詢的例子如下:
SELECT * FROM article WHERE uid IN(SELECT uid FROM user WHERE status=1)
對應(yīng)的兩個數(shù)據(jù)表如下:
article 文章表:

user 用戶表:

查詢返回結(jié)果如下所示:

在該例子中,首先通過子查詢語句查詢出所有 status=1 的 uid,實(shí)際的查詢類似于:
SELECT * FROM article WHERE uid IN(1,2)
MySQL 標(biāo)量子查詢
標(biāo)量子查詢是指子查詢返回的是單一值的標(biāo)量,如一個數(shù)字或一個字符串,也是子查詢中最簡單的返回形式。
一個標(biāo)量子查詢的例子如下:
SELECT * FROM article WHERE uid = (SELECT uid FROM user WHERE status=1 ORDER BY uid DESC LIMIT 1)
在該例子中,子查詢語句:
SELECT uid FROM user WHERE status = 1 ORDER BY uid DESC LIMIT 1
返回的是單一的數(shù)字(如 2),實(shí)際的查詢語句為:
SELECT * FROM article WHERE uid = 2
使用子查詢進(jìn)行比較
可以使用 = > < >= <= <> 這些操作符對子查詢的標(biāo)量結(jié)果進(jìn)行比較,通常子查詢的位置在比較式的右側(cè):
SELECT * FROM t1 WHERE column1 = (SELECT MAX(column2) FROM t2)
提示
對于采用這些操作符之一進(jìn)行的比較,子查詢必須返回一個標(biāo)量。唯一的例外是 = 可以和行子查詢同時使用。
子查詢與表連接
在很多情況下,子查詢的效果與 JOIN 表連接很類似,但一些特殊情況下,是必須用子查詢而不能用表連接的,如:
SELECT * FROM t1 WHERE column1 = (SELECT MAX(column2) FROM t2)
以及下例:
SELECT * FROM article AS t WHERE 2 = (SELECT COUNT(*) FROM article WHERE article.uid = t.uid)
該例子要找出用戶發(fā)表了 2 篇文章的所有文章記錄。對應(yīng)的兩個數(shù)據(jù)表如下:
article 文章表:

user 用戶表:

查詢返回結(jié)果如下所示:

相關(guān)文章
MySQL 4G內(nèi)存服務(wù)器配置優(yōu)化
MySQL對于web架構(gòu)性能的影響最大,也是關(guān)鍵的核心部分。下面我們了解一下MySQL優(yōu)化的一些基礎(chǔ),MySQL自身(my.cnf)的優(yōu)化2017-07-07
MySQL不使用order by實(shí)現(xiàn)排名的三種思路總結(jié)
ORDER BY語句用于根據(jù)指定的列對結(jié)果集進(jìn)行排序,在日常開發(fā)中也經(jīng)常會用到,但下面這篇文章主要給大家介紹了關(guān)于MySQL不使用order by實(shí)現(xiàn)排名的三種思路,需要的朋友可以參考下2021-06-06
SQL中current_date()函數(shù)的實(shí)現(xiàn)
日期時間類型的數(shù)據(jù)也是經(jīng)常要用到的,SQL中也提供了一些函數(shù)對這些數(shù)據(jù)進(jìn)行處理,本文主要介紹了SQL中current_date()函數(shù)的實(shí)現(xiàn),具有一定的參考價值2024-02-02
在Hadoop集群環(huán)境中為MySQL安裝配置Sqoop的教程
這篇文章主要介紹了在Hadoop集群環(huán)境中為MySQL安裝配置Sqoop的教程,Sqoop一般被用于數(shù)據(jù)庫軟件之間的數(shù)據(jù)遷移,需要的朋友可以參考下2015-12-12
關(guān)于Mysql中ON與Where區(qū)別問題詳解
在編寫SQL腳本中,多表連接查詢操作需要使用到on和where條件,但是經(jīng)常會混淆兩者的用法,從而造成取數(shù)錯誤,下面這篇文章主要給大家介紹了關(guān)于Mysql中ON與Where區(qū)別問題的相關(guān)資料,需要的朋友可以參考下2022-02-02
Mysql使用索引實(shí)現(xiàn)查詢優(yōu)化
索引的目的在于提高查詢效率,本文給大家介紹Mysql使用索引實(shí)現(xiàn)查詢優(yōu)化技巧,涉及到索引的優(yōu)點(diǎn)等方面的知識點(diǎn),非常不錯,具有參考借鑒價值,感興趣的朋友一起看下吧2016-07-07

