news 2026/5/25 8:53:08

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/5/24 2:07:58

Vision Transformer瘦身指南:如何将1243MiB大模型压缩到37MiB

还在为Vision Transformer的庞大体积发愁吗&#xff1f;想要在移动设备上部署ViT却频频碰壁&#xff1f;别担心&#xff0c;本文将带你掌握ViT模型从"巨无霸"到"小精灵"的魔法变身术&#xff01;&#x1f680; 【免费下载链接】vision_transformer 项目…

作者头像 李华
网站建设 2026/5/24 22:20:54

_医院档案管理系统的设计与实现(11465)

有需要的同学&#xff0c;源代码和配套文档领取&#xff0c;加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码&#xff08;前后端源代码SQL脚本&#xff09;配套文档&#xff08;LWPPT开题报告&#xff09;远程调试控屏包运行 三、技术介绍 Java…

作者头像 李华
网站建设 2026/5/21 1:57:26

万能引用和右值引用的区别

从定义、语法、核心区别和使用场景四个方面&#xff0c;用通俗的语言和例子彻底分清。首先要明确一个核心结论&#xff1a;万能引用不是一种新的引用类型&#xff0c;而是auto&&或模板参数T&&在特定条件下的一种 “语法现象”&#xff0c;它可以绑定左值或右值…

作者头像 李华
网站建设 2026/5/21 18:53:36

如何搭建接口自动化测试框架?

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快一、原理及特点参数放在XML文件中进行管理用httpClient简单封装一个httpUtils工具类测试用例管理使用了testNg管理&#xff0c;使用了TestNG参数化测试&#xff0c;…

作者头像 李华
网站建设 2026/5/24 13:44:49

Ruby编程最佳实践

Ruby编程最佳实践 【免费下载链接】md2key Convert markdown to keynote 项目地址: https://gitcode.com/gh_mirrors/md/md2key 您的名字 代码规范 使用有意义的变量名保持方法简短专注编写清晰的注释 性能优化技巧 避免不必要的对象创建合理使用缓存机制优化数据库…

作者头像 李华
网站建设 2026/5/22 8:40:47

【前端】从零开始搭建现代前端框架:React 19、Vite、Tailwind CSS、ShadCN UI-第四章《统一的代码风格与严格的代码质量检查,ESLint 与 Prettier的配置 》

第4章&#xff1a;统一的代码风格与严格的代码质量检查&#xff0c;为项目安装配置ESLint和Prettier在现代前端项目中&#xff0c;ESLint 与 Prettier 的工程化整合非常关键&#xff0c;它决定了&#xff1a;团队代码是否统一自动化格式化是否生效是否能在 VSCode Git Hooks 中…

作者头像 李华