MySQL 基础:SELECT、WHERE、JOIN 的第一次使用

不用怕数据库,跟着这三个单词,你就能查到你想要的一切。

欢迎来到 《大一突围》 专栏。很多大一同学第一次接触 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 连接 studentsscores

  • 需要 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;

结果:

六、给大一新生的三个建议

  1. 先在本机安装 MySQL + Workbench ,或者使用免费的在线练习平台(如 SQLZoo、LeetCode 的数据库题库),手打所有例子

  2. 把 JOIN 想象成"VLOOKUP":就像 Excel 里根据 ID 去另一张表找信息。

  3. 不要背语法,背逻辑SELECT(选哪几列)→ FROM(从哪张表)→ JOIN(连哪张表)→ WHERE(筛选哪些行)。

❓ 问题:如果你是第一次写 SQL,试着回答:查询"所有选了'数据库'课程且成绩大于 80 分的学生姓名",SQL 应该怎么写?欢迎在评论区写下你的答案,我会选出两位幸运同学送《SQL 必知必会》电子版学习资料。

📌 觉得有用请点 👍 + 关注 ,本专栏 《大一突围》 下期预告:

👉 《Git 从零到 PR:大一新生第一个开源贡献》

收藏 + 转发给需要学数据库的同学,一起入门 SQL 不踩坑。

相关推荐
weelinking11 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
稳联技术老娜11 小时前
DeviceNet主站怎么连接西门子PLC,Profinet网关配置手册(那智机器人)
服务器·网络·数据库
这个DBA有点耶12 小时前
云上运维新挑战:当数据库不再“看得见摸得着”
数据库·sql·程序人生·云原生·运维开发·学习方法·dba
AskHarries13 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
消失在人海中13 小时前
oracle 数据库多表关联查询
服务器·数据库·oracle
九皇叔叔13 小时前
PostgreSQL/openGauss pg_stats 视图从入门到精通:统计信息、执行计划与慢 SQL 优化实战
数据库·sql·postgresql
南极企鹅14 小时前
MySQL间隙锁&临键锁
数据库·sql·mysql
TDengine (老段)15 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
苏渡苇16 小时前
Redis 持久化——RDB 快照 vs AOF 日志
数据库·redis·缓存·redis持久化·aof vs rdb
l1t17 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器
数据库·sql