MySQL的SELECT語句是使用最為頻繁的操作之一。其中,子表查詢是一種常見的查詢方式,用于在一個查詢中使用子查詢結果。下面將介紹如何使用SELECT子表。
首先,我們先創(chuàng)建一個表格。比如說,我們創(chuàng)建一個名為“students”的表格,包含“學生ID”、“姓名”和“成績”三個字段。以下為表格的創(chuàng)建代碼:
CREATE TABLE students ( student_id INT PRIMARY KEY, student_name VARCHAR(50) NOT NULL, score INT NOT NULL DEFAULT 0 );接下來,我們插入一些數(shù)據(jù)用于演示。以下為插入數(shù)據(jù)的代碼:
INSERT INTO students (student_id, student_name, score) VALUES (1, '張三', 90), (2, '李四', 80), (3, '王五', 70), (4, '趙六', 60);現(xiàn)在,我們開始使用SELECT子表查詢數(shù)據(jù)。假設我們需要查詢“成績”最高的學生的“姓名”,可使用如下代碼:
SELECT student_name FROM students WHERE score = (SELECT MAX(score) FROM students);在上述代碼中,我們使用了兩個SELECT語句。第一個SELECT語句用于查詢“學生姓名”,而第二個SELECT語句是子查詢,用于查詢“成績”最高的學生的成績。 下面再看一個例子。假設我們需要查詢“成績”最高的學生的“姓名”和“成績”,以及“成績”最低的學生的“姓名”和“成績”,可使用如下代碼:
SELECT student_name, score FROM students WHERE score = (SELECT MAX(score) FROM students) UNION ALL SELECT student_name, score FROM students WHERE score = (SELECT MIN(score) FROM students);在上述代碼中,我們使用了UNION ALL運算符連接兩個SELECT語句的結果。第一個SELECT語句用于查詢“成績”最高的學生的信息,而第二個SELECT語句用于查詢“成績”最低的學生的信息。 總結一下,SELECT子表是一種強大的查詢方式,可以在一個查詢中使用子查詢結果。雖然SELECT子表的語法比較復雜,但掌握了這一查詢技巧之后,可以在實際應用中大大提升查詢效率。