news 2026/6/8 12:06:03

SQL 从基础操作到高级查询

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL 从基础操作到高级查询

文章目录

  • SQL从基础操作到高级查询
    • 一、SQL基础操作
      • 1.1 数据查询(SELECT)
      • 1.2 数据操作
        • 插入数据(INSERT)
        • 更新数据(UPDATE)
        • 删除数据(DELETE)
    • 二、高级查询技巧
      • 2.1 WHERE子句高级用法
      • 2.2 排序与分组
        • ORDER BY排序
        • GROUP BY分组
        • HAVING过滤分组
      • 2.3 限制查询结果
        • LIMIT限制行数
        • OFFSET偏移量
    • 三、表结构管理
      • 3.1 修改表结构(ALTER TABLE)
        • 添加字段
        • 修改字段
        • 删除字段
        • 重命名字段
      • 3.2 表级操作
        • 修改字符集
        • 重命名表
      • 3.3 删除表
    • 四、数据连接操作
      • 4.1 内连接(INNER JOIN)
      • 4.2 外连接
        • 左外连接(LEFT JOIN)
        • 右外连接(RIGHT JOIN)
      • 4.3 集合操作
        • UNION(去重合并)
        • UNION ALL(不去重复合)
    • 五、SQL分类体系
      • 5.1 数据查询语言(DQL)
      • 5.2 数据操作语言(DML)
      • 5.3 数据定义语言(DDL)
      • 5.4 数据控制语言(DCL)
      • 5.5 事务控制语言(TCL)
    • 六、实用技巧
      • 6.1 数据导入导出
      • 6.2 查看数据库信息

SQL从基础操作到高级查询

SQL(结构化查询语言)是管理和操作关系型数据库的核心工具,广泛应用于数据查询、管理和维护。本文将系统梳理SQL的核心知识点,涵盖数据操作、表结构管理、查询优化及SQL分类等内容,帮助你构建完整的SQL知识体系。

一、SQL基础操作

1.1 数据查询(SELECT)

SELECT语句用于从数据库中检索数据,是SQL中最常用的命令。

SELECTcolumn1,column2,...FROMtable_nameWHEREcondition;
  • 使用*选择所有列
  • WHERE子句用于过滤数据
  • 支持条件组合(AND、OR、NOT)
-- 查询所有男性学生SELECT*FROMstudentWHEREsex='男';

1.2 数据操作

插入数据(INSERT)
INSERTINTOtable_name(column1,column2,column3,...)VALUES(value1,value2,value3,...);
更新数据(UPDATE)
UPDATEtable_nameSETcolumn1=value1,column2=value2,...WHEREsome_column=some_value;
删除数据(DELETE)
DELETEFROMtable_nameWHEREsome_column=some_value;

注意:不指定WHERE条件将删除表中所有数据!

二、高级查询技巧

2.1 WHERE子句高级用法

-- 模糊匹配(多字符)SELECT*FROMstudentsWHEREclazzLIKE'xx%';-- 模糊匹配(单字符)SELECT*FROMstudentsWHEREstu_nameLIKE'张_';-- 多关键词匹配SELECT*FROMstudentsWHEREnameRLIKE'张|李|王';-- IN操作符SELECT*FROMstudentsWHEREclazzIN('xx','xx','xx');-- BETWEEN范围查询SELECT*FROMstudentsWHEREageBETWEEN22AND24;

2.2 排序与分组

ORDER BY排序
SELECTcolumn1,column2,...FROMtable_nameORDERBYcolumn1[ASC|DESC],column2[ASC|DESC],...;
GROUP BY分组
SELECTcolumn1,column2,...,AVG(column_name)FROMtable_nameGROUPBYcolumn1,column2,...;
HAVING过滤分组
SELECTcolumn1,column2,...,aggregate_function(column_name)FROMtable_nameGROUPBYcolumn1,column2,...HAVINGcondition;

2.3 限制查询结果

LIMIT限制行数
-- 限制返回10行SELECT*FROMstudentsLIMIT10;-- 从第5行开始,返回10行SELECT*FROMstudentsLIMIT5,10;
OFFSET偏移量
SELECTcolumn1,column2,...FROMtable_nameLIMITnumberOFFSEToffset;

三、表结构管理

3.1 修改表结构(ALTER TABLE)

添加字段
-- 增加字段ALTERTABLEstudentsADD[COLUMN]dateTDATE;-- 增加字段并设置默认值ALTERTABLEstudentsADDdateTDATEDEFAULT"2025-12-12";
修改字段
-- 修改字段类型ALTERTABLEstudentsMODIFYdataTDATETIME;-- 修改字段注释ALTERTABLEstudentsMODIFYdateTDATECOMMENT"日期";-- 修改字段约束ALTERTABLEstudentsMODIFYstu_idINTNOTNULL;
删除字段
ALTERTABLEstudentsDROPlength;
重命名字段
ALTERTABLEstudents CHANGE stu_id sidVARCHAR(255);

3.2 表级操作

修改字符集
ALTERTABLEstudentsCHARACTERSETutf8;
重命名表
ALTERTABLEstudentsRENAMETOstudent;-- 或RENAMETABLEstudentsTOstudent;

3.3 删除表

DROPTABLE[IFEXISTS]students;

四、数据连接操作

4.1 内连接(INNER JOIN)

SELECTs.*,sc.subject_id,su.subject_nameFROM(students sJOINscores scJOINsubjects suONs.stu_id=sc.stu_idANDsc.subject_id=su.subject_id);

4.2 外连接

左外连接(LEFT JOIN)
SELECT*FROMstudentsASsLEFTJOINscoresASscONs.stu_id=sc.stu_id;
右外连接(RIGHT JOIN)
SELECT*FROMstudentsASsRIGHTJOINscoresASscONs.stu_id=sc.stu_id;

4.3 集合操作

UNION(去重合并)
SELECTs.stu_id,s.stu_name,sc.score,su.subject_nameFROMstudents sJOINscores scONs.stu_id=sc.stu_idJOINsubjects suONsc.subject_id=su.subject_idWHEREsc.score>=90UNIONSELECTs.stu_id,s.stu_name,sc.score,su.subject_nameFROMstudents sJOINscores scONs.stu_id=sc.stu_idJOINsubjects suONsc.subject_id=su.subject_idWHEREsc.score<=60ORDERBYscoreDESC;
UNION ALL(不去重复合)
SELECTnameFROMstudentsWHEREage=20UNIONALLSELECTnameFROMstudentsWHEREage=19;

五、SQL分类体系

5.1 数据查询语言(DQL)

核心作用:查询/检索数据(只读)
关键字:SELECT、FROM、WHERE、GROUP BY、HAVING、ORDER BY、LIMIT、JOIN

5.2 数据操作语言(DML)

核心作用:增删改数据内容
关键字:INSERT、UPDATE、DELETE、MERGE

5.3 数据定义语言(DDL)

核心作用:定义/修改数据库结构
关键字:CREATE、ALTER、DROP、TRUNCATE、RENAME

  • CREATE、ALTER、DROP:可以复原

5.4 数据控制语言(DCL)

核心作用:管理权限和事务
关键字:GRANT、REVOKE、COMMIT、ROLLBACK

5.5 事务控制语言(TCL)

核心作用:事务管理(DCL子集)
关键字:COMMIT、ROLLBACK、SAVEPOINT

六、实用技巧

6.1 数据导入导出

# 导入数据LOAD DATA LOCAL INFILE'路径'INTO TABLE 表名 FIELDS TERMINATED BY'分隔符';# 导出数据mysqldump -uroot -p stu students>/root/data/mydb.sql# 备份并压缩aliasdb_backup='mysqldump -uroot -p --single-transaction stu students | gzip > /root/data/mydb_$(date+%Y%m%d).sql.gz'

6.2 查看数据库信息

-- 查看表结构SHOWCREATETABLEstudents;-- 查看当前数据库SELECTDATABASE();
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/8 22:35:10

告别修图烦恼!FLUX Kontext颠覆性AI图像编辑零门槛上手指南

告别修图烦恼&#xff01;FLUX Kontext颠覆性AI图像编辑零门槛上手指南 【免费下载链接】kontext-make-person-real 项目地址: https://ai.gitcode.com/hf_mirrors/fofr/kontext-make-person-real 还在为复杂的Photoshop操作头疼吗&#xff1f;面对一张完美的照片&…

作者头像 李华
网站建设 2026/6/7 21:19:55

Pr制作视频的基本流程:从粗剪到配字幕

对剪辑师来说&#xff0c;Pr 做视频的流程总像 “一团乱麻”&#xff1a;粗剪素材反复调&#xff0c;加字幕要手动输&#xff0c;找贴纸还得四处翻资源 —— 尤其新手&#xff0c;光理清楚步骤就得耗半天。其实 Pr 做视频有清晰流程&#xff01;今天把Pr 从界面认知到加字幕、贴…

作者头像 李华
网站建设 2026/6/7 21:47:17

宁波某高端酒店资产数字化:72小时售罄5000分的会员升级

如果你还在为会员沉睡、复购率低、现金流紧张而头疼&#xff0c;宁波一家高端酒店的做法可能会让你眼前一亮。他们只做了一件事&#xff1a;把传统会员卡换成“数字权益卡”。结果&#xff1f;限量5000份&#xff0c;72小时售罄&#xff0c;提前锁定全年现金流&#xff0c;还吸…

作者头像 李华
网站建设 2026/6/8 8:23:55

2026年1月必参加的学术会议推荐!人工智能、大数据、通信网络、物联网、生物医学、光电科学、电力电气工程、智能制造、电子信息工程、遥感测绘、图像处理、自动化、算法、计算机工程、机器人等主题可选!...

会议往期历史 | 投稿参会优惠 | 论文检索周期 |会议模板论文 | 主题是否匹配 | 更多事宜 会议名称 会议时间 地点 2026年智能物联网与智慧生活国际学术会议&#xff08;IoT-Life 2026&#xff09; 2026年1月7-9日 东京 2026年人机交互、神经网络与深度学习国际学术会议&a…

作者头像 李华
网站建设 2026/6/9 5:06:17

欧陆直流调速器650-43135020-BF1P00-A0怎么调试

针对欧陆直流调速器650-43135020-BF1P00-A0的调试&#xff0c;可参考以下通用调试步骤&#xff0c;这些步骤基于欧陆直流调速器的常见调试流程整理&#xff0c;适用于多数型号&#xff0c;包括您提到的型号&#xff1a;一、调试前准备确认设备连接&#xff1a;确保调速器与电机…

作者头像 李华