假设我们有两个表,一个是students
表,包含学生的姓名和学号,另一个是courses
表,包含课程的名称和课程号。我们希望得到一个包含所有学生和所有课程的组合的结果集。
首先,创建students
表并插入一些数据:
CREATE TABLE students (
student_id INT PRIMARY KEY,
student_name VARCHAR(50)
);
INSERT INTO students (student_id, student_name) VALUES
(1, 'Alice'),
(2, 'Bob'),
(3, 'Charlie');
然后创建courses
表并插入一些数据:
CREATE TABLE courses (
course_id INT PRIMARY KEY,
course_name VARCHAR(50)
);
INSERT INTO courses (course_id, course_name) VALUES
(101, 'Math'),
(102, 'Science'),
(103, 'History');
现在,使用CROSS JOIN
操作来获取所有学生和所有课程的组合:
SELECT students.student_name, courses.course_name
FROM students
CROSS JOIN courses;
这将得到如下结果集:
student_name | course_name
-------------|------------
Alice | Math
Alice | Science
Alice | History
Bob | Math
Bob | Science
Bob | History
Charlie | Math
Charlie | Science
Charlie | History
在这个例子中,我们使用CROSS JOIN
操作获取了所有学生和所有课程的组合。这种操作在需要获取多个表之间的所有可能组合时非常有用。