不用怕数据库,跟着这三个单词,你就能查到你想要的一切。
欢迎来到 《大一突围》 专栏。很多大一同学第一次接触 MySQL,看到"数据库"三个字就觉得很难。其实,你日常生活中每天都在"查数据"------查成绩、翻通讯录、筛选淘宝商品......
SQL(结构化查询语言)就是跟数据库说话的语言。而 SELECT、WHERE、JOIN 这三个,占了日常查询的 90% 以上。今天我们用学生-课程-成绩这个最经典的例子,带你写出人生第一条有意义的 SQL。

一、准备工作:两张小表(所有例子都能跑)
为了让你立刻动手,我建了两个极其简单的表:
📄 表1:students(学生表)

📄 表2:scores(成绩表)

它们的关联关系如下图:



二、SELECT:最简单的查询(我要看什么)
sql
SELECT 列名1, 列名2 FROM 表名;
这就像从一个大箱子里捡出你需要的物品。
例子1:查询所有学生的姓名和专业
sql
SELECT name, major FROM students;
结果:

例子2 :查询所有列(用 * 通配符)
sql
SELECT * FROM students;
这会返回整张表的全部内容。
Mermaid 流程图 -- SELECT 执行逻辑 :
三、WHERE:给查询加条件(我要什么)
很多时候你不想要全部数据,只想筛选出符合某些条件的行。这时用 WHERE。
sql
SELECT 列名 FROM 表名 WHERE 条件;
例子3:只查询计算机专业的学生
sql
SELECT name, major FROM students WHERE major = '计算机';
结果:
例子4:成绩大于等于 80 分的记录
sql
SELECT * FROM scores WHERE score >= 80;
结果:

常用 WHERE 条件符号 :=、>、<、>=、<=、<>(不等于)、LIKE(模糊匹配)、AND / OR。
Mermaid 对比图 -- 不带 WHERE vs 带 WHERE:

四、JOIN:把多张表连在一起(我要关联信息)
这是很多新手的第一个"拦路虎"。但请你记住:JOIN 就是根据某个共同的字段,把两张表的行拼在一起。
最常见的 JOIN 是 INNER JOIN(内连接),它只返回两个表中都能匹配上的行。
sql
SELECT 列名
FROM 表A
INNER JOIN 表B ON 表A.关联字段 = 表B.关联字段;
例子5:查询每个学生对应的成绩(显示学生姓名、课程、分数)
学生名字在 students 表,成绩在 scores 表,通过 student_id 连接。
sql
SELECT students.name, scores.course, scores.score
FROM students
INNER JOIN scores ON students.student_id = scores.student_id;
结果:

Mermaid 图解 -- JOIN 就像拼积木:

实际 INNER JOIN 只会保留那些在 scores 表里有成绩的学生。如果某个学生没有成绩(不存在的 student_id),就不会出现在结果中。
五、综合实战:一条 SQL 同时使用 SELECT、WHERE 和 JOIN
需求:查询计算机专业学生的所有课程成绩,只显示分数 ≥ 80 的记录。
拆解:
-
需要
JOIN连接students和scores -
需要
WHERE筛选major = '计算机'且score >= 80
sql
SELECT students.name, scores.course, scores.score
FROM students
INNER JOIN scores ON students.student_id = scores.student_id
WHERE students.major = '计算机' AND scores.score >= 80;
结果:

六、给大一新生的三个建议
-
先在本机安装 MySQL + Workbench ,或者使用免费的在线练习平台(如 SQLZoo、LeetCode 的数据库题库),手打所有例子。
-
把 JOIN 想象成"VLOOKUP":就像 Excel 里根据 ID 去另一张表找信息。
-
不要背语法,背逻辑 :
SELECT(选哪几列)→FROM(从哪张表)→JOIN(连哪张表)→WHERE(筛选哪些行)。
❓ 问题:如果你是第一次写 SQL,试着回答:查询"所有选了'数据库'课程且成绩大于 80 分的学生姓名",SQL 应该怎么写?欢迎在评论区写下你的答案,我会选出两位幸运同学送《SQL 必知必会》电子版学习资料。
📌 觉得有用请点 👍 + 关注 ,本专栏 《大一突围》 下期预告:
👉 《Git 从零到 PR:大一新生第一个开源贡献》
收藏 + 转发给需要学数据库的同学,一起入门 SQL 不踩坑。