MySQL笔记-基础篇(一):查询

news2024/9/23 15:19:33

博客主页:     南来_北往

系列专栏:Spring Boot实战


MySQL是一种广泛使用的关系型数据库管理系统,它基于结构化查询语言(SQL)来管理和操作数据。下面将依次探讨MySQL查询的各个方面,确保理解扎实,能够在实际工作中运用。具体分析如下:

  1. 基础查询语句

    • 查询字段:在MySQL中,查询一个或多个字段是最基本的操作。可以通过SELECT语句实现这一点。例如,查询单个字段“last_name”可以使用“SELECT last_name FROM employees;”。若要查询多个字段,比如“last_name”和“first_name”,则可以使用“SELECT last_name, first_name FROM employees;”。
    • 查询所有字段:如果需要查询表中的所有字段,可以使用星号(*)通配符。例如,查询employees表的所有字段可以写作“SELECT * FROM employees;”。
    • 查询常量和表达式:除了查询字段外,还可以查询常量值和表达式的结果。比如,“SELECT 10 AS constant;”将返回一个名为constant的列,包含数值10。对于表达式,例如“SELECT 100 / 9 AS result;”将会计算该表达式并返回结果。
    • 查询函数:MySQL支持在查询中使用函数。如使用版本信息函数“SELECT VERSION();”将返回数据库的版本信息。
    • 起别名:在查询时可以为字段或表达式设置别名,以提高结果集的可读性。使用AS关键字为字段设置别名,如“SELECT last_name AS surname, first_name AS forename FROM employees;”。如果不使用AS,可以直接在字段名后跟上别名,例如“SELECT last_name surname, first_name forename FROM employees;”。
  2. 条件查询

    • 按条件表达式筛选:通过在WHERE子句中指定条件来筛选数据。例如,要找出salary大于12000的员工信息,可以使用“SELECT * FROM employees WHERE salary > 12000;”。
    • 按逻辑表达式筛选:可以使用逻辑运算符构建更复杂的筛选条件。比如,查询工资在10000到20000之间的员工信息,可以使用“SELECT last_name, salary, commission_pct FROM employees WHERE salary >= 10000 AND salary <= 20000;”。
    • 模糊查询:LIKE运算符允许进行模糊匹配,通常与通配符一起使用。例如,要查找last_name字段中包含字母"a"的所有员工信息,可以使用“SELECT * FROM employees WHERE last_name LIKE '%a%';”。
    • BETWEEN AND范围查询:BETWEEN AND用于查询在指定范围内的值。例如,要选择employee_id在100到120之间的员工信息,可以使用“SELECT * FROM employees WHERE employee_id BETWEEN 100 AND 120;”。
    • IN列表查询:IN操作符允许指定一个值列表,查询某个字段是否在这些值中的记录。比如,要找出job_id为'IT_PROG'或'AD_VP'的员工信息,可以写作“SELECT last_name, job_id FROM employees WHERE job_id IN ('IT_PROG', 'AD_VP');”。
    • NULL值处理:IS NULL和IS NOT NULL操作符可以用来判断字段值是否为NULL。例如,要找出没有奖金的员工信息,可以使用“SELECT last_name FROM employees WHERE commission_pct IS NULL;”。
  3. 排序和分页查询

    • 排序查询:使用ORDER BY子句可以根据一个或多个字段对结果集进行排序。例如,要按照salary降序排列员工信息,可以写为“SELECT * FROM employees ORDER BY salary DESC;”。
    • 分页查询:当结果集较大时,为了方便查看,可以使用LIMIT子句进行分页。假设每页显示10条记录,要查询第3页的内容,可以使用“SELECT * FROM employees ORDER BY salary DESC LIMIT 20, 10;”这样会跳过前20条记录,然后取得接下来的10条。
  4. 复杂查询

    • 聚合函数:聚合函数能够对一组值执行计算,返回单个值。常用的聚合函数包括COUNT、SUM、AVG、MAX和MIN。比如,要统计每个部门的员工数量,可以使用“SELECT department_id, COUNT(*) FROM employees GROUP BY department_id;”。
    • 分组查询:使用GROUP BY子句可以根据一个或多个列将结果集划分成组。在进行分组查询时,SELECT子句中的非聚合列通常是GROUP BY子句中的列。例如,查询每个部门平均工资可以使用“SELECT department_id, AVG(salary) AS average_salary FROM employees GROUP BY department_id;”。
    • HAVING子句筛选:HAVING子句用于在GROUP BY查询中添加筛选条件,类似于WHERE子句,但作用于组,而非个别记录。例如,要找出平均工资大于30000的部门,可以使用“SELECT department_id, AVG(salary) AS average_salary FROM employees GROUP BY department_id HAVING AVG(salary) > 30000;”。
  5. 联查查询

    • 内连接:内连接(INNER JOIN)只返回两个表中匹配条件的记录。例如,如果有两个表employees和departments,想查询所有员工及其对应的部门信息,可以使用“SELECT employees.last_name, employees.department_id, departments.department_name FROM employees INNER JOIN departments ON employees.department_id = departments.department_id;”。
    • 外连接:与内连接不同,外连接(OUTER JOIN)不仅返回匹配的记录,还返回其中一个表中不匹配的记录。例如,左外连接(LEFT OUTER JOIN)会返回左表(employees)的所有记录以及右表(departments)中匹配的记录。如果没有匹配,结果是NULL。其语法为“SELECT employees.last_name, employees.department_id, departments.department_name FROM employees LEFT OUTER JOIN departments ON employees.department_id = departments.department_id;”。
    • 自连接:自连接是同一个表内部的连接,通常用于比较表中的行或者找到满足特定关系的不同行。比如,要找出同一部门内员工薪水的差异,可以使用自连接。“SELECT e1.last_name AS employee1, e2.last_name AS employee2, ABS(e1.salary - e2.salary) AS salary_difference FROM employees e1 JOIN employees e2 ON e1.department_id = e2.department_id WHERE e1.employee_id != e2.employee_id;”。
  6. 子查询

    • 单行子查询:子查询是嵌套在另一个SQL查询中的查询,可以放在WHERE或HAVING子句中,也可以作为表达式的一部分。单行子查询是指只返回一个值的子查询。例如,要找出薪水最高的员工信息,主查询会使用子查询返回的最高薪水作为参照:“SELECT last_name, salary FROM employees WHERE salary = (SELECT MAX(salary) FROM employees);”。
    • 多行子查询:多行子查询返回一组值,可以使用IN操作符来检查主查询中的值是否在子查询返回的值列表中。例如,查找所有属于部门名称为"Sales"的员工的详细信息:“SELECT last_name, department_id FROM employees WHERE department_id IN (SELECT department_id FROM departments WHERE department_name = 'Sales');”。
    • 关联子查询:关联子查询是指子查询引用了外部查询中的表。这种类型的子查询可以根据外部查询的每一行动态地生成结果。例如,要找出每个员工的工资等级(即比该员工工资高的员工的数目),可以使用:“SELECT last_name, salary, (SELECT COUNT(*) FROM employees e2 WHERE e2.salary > e1.salary) AS salary_rank FROM employees e1;”。

掌握MySQL的基础查询是理解和使用数据库的重要步骤。从简单的字段查询到复杂的子查询和连接查询,每种查询都有其特定的应用场景和功能。此外,各种查询相关的注意事项也需要特别留心:

  • 注释的重要性:在编写复杂的SQL查询时,不要忘记利用注释来提高代码的可读性和维护性。MySQL中可以使用“--”为单行注释,“/* */”为多行注释。
  • 字符集和校对:在设计数据库和写入查询时应注意字符集和校对规则的选择,以确保正确处理不同语言和编码的文本数据。
  • 索引的使用:了解何时使用索引能大幅提高查询性能,特别是在处理大量数据时。创建合适的索引可以加快检索速度,但同时也会影响数据的更新操作和占用额外的存储空间。
  • 安全性考虑:在公开的查询中避免直接暴露敏感信息,同时合理配置用户权限,防止未授权的数据访问或改动。

综上所述,MySQL查询是数据库操作的核心内容之一,它不仅涉及基本的SELECT语句,还包括复杂的连接、聚合和子查询等高级用法。要想熟练掌握这些技能,除了理论学习之外,实践操作同样重要。建议定期进行练习,并通过案例分析来深化理解。随着经验的积累,你将能够更加高效地利用MySQL进行数据管理和信息提取。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1993695.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

“阳光高考爬虫项目揭秘:增量爬虫与断点续抓的Python实战“

阳光高考项目 项目要求 爬取各大高校基本信息和招生简章&#xff08;招生简章要求存储为pdf格式并且入库&#xff09; 数据库表设计 idtask_urlstatus&#xff1a;0(未抓取)&#xff0c;1(抓取中)&#xff0c;2(抓取完毕)&#xff0c;3(错误)&#xff0c;4(更新中)&#xff…

C语言小练习(叁)

个人练习&#xff1a; 编程题&#xff1a; 1.编写一个函数&#xff0c;通过输入球的半径&#xff0c;返回球的体积&#xff1b; #include <stdio.h> #define pi 3.14 //计算球体积的函数 double v_ball(double r) {return 4.0 / 3.0 * pi * r * r * r; }int main() {d…

InfluxDB Studio 下载,时序数据库Windows图形界面操作

下载地址&#xff1a; https://github.com/CymaticLabs/InfluxDBStudio/releases解压缩后&#xff0c;双击 InfluxDBStudio.exe 运行。 参考 windows下 influxDB 操作工具 InfluxDBStudio 吐槽 现在 CSDN 太恶心了&#xff0c;动不动就让订阅或者积分下载资源。诚然&#…

【Python学习-UI界面】pyqt5页面布局

1、布局分类 序号类别描述1QBoxLayout可将小部件垂直或水平排列。它的派生类有QVBoxLayout&#xff08;用于垂直排列小部件&#xff09;和QHBoxLayout&#xff08;用于水平排列小部件&#xff09;。2QGridLayout对象呈现为行和列排列的单元格网格。该类包含addWidget()方法&am…

艾迈斯欧司朗推出突破性8通道915nm SMT脉冲激光器,开创激光雷达应用新时代

8通道915nm SMT脉冲激光器可增强自动驾驶汽车的远距离激光雷达系统&#xff1b;经过AEC-Q102认证的8通道QFN封装&#xff0c;具有高性能和高效率&#xff0c;采用艾迈斯欧司朗专有的波长稳定技术&#xff1b;基于20多年的脉冲激光器技术经验。 中国 上海&#xff0c;2024年8月8…

JAVA开发学习-day21

JAVA开发学习-day21 1. 删除表单数据 根据ElementUI的官方组件指南&#xff0c;为表单每列的数据添加删除按钮 <el-table :data"tableData" style"width: 100%"><el-table-column prop"id" label"ID" width"180"…

那些你应该掌握的linux命令

一、路径授权 要给 a 用户 b 路径的所有操作权限,可以使用以下命令&#xff1a; sudo chown -R a:a /b sudo chmod -R 770 /b1.sudo chown -R a:a /b chown 命令用于更改文件或目录的所有者和所属组。-R 选项表示递归地应用于目录及其内部的所有文件和子目录。a:a 表示将所有…

24/8/8算法笔记 条件筛选决策树根节点

筛选决策树的根节点是建立决策树过程中的一个重要步骤&#xff0c;主要原因包括&#xff1a; 减少计算量&#xff1a;选择合适的根节点可以减少树的深度&#xff0c;从而减少模型训练和预测时的计算量。 提高模型性能&#xff1a;选择最佳分裂点可以最大化模型的性能&#xff…

更换低版本jdk8后的idea页面怎么换回来

一、问题阐述 一开始我的idea是下面的界面&#xff1a; 这个页面美观&#xff0c;简洁。后来因为工作需要&#xff0c;从jdk17切换到jdk8的时候&#xff0c;页面变了 这个没有前面的好看&#xff0c;怎么回事&#xff1f; 二、解决方案 1、file——setting 2、搜索ui——New UI…

全新博客X主题/简约WordPress主题模板/主题巴巴/免授权版源码+自适应设计

源码简介&#xff1a; 博客X这款超酷的Wordpress主题&#xff0c;是主题巴巴团队打造的设计杰作。想象一下&#xff0c;你的博客首页能展示那些炫酷的幻灯片置顶文章、还有各种精心策划的专题列表&#xff0c;这些内容模块的设计简直吸睛了&#xff0c;能让来访的用户眼前一亮…

JAVA集中学习第四周学习记录(三)

系列文章目录 第一章 JAVA集中学习第一周学习记录(一) 第二章 JAVA集中学习第一周项目实践 第三章 JAVA集中学习第一周学习记录(二) 第四章 JAVA集中学习第一周课后习题 第五章 JAVA集中学习第二周学习记录(一) 第六章 JAVA集中学习第二周项目实践 第七章 JAVA集中学习第二周学…

SSL VPN综合实验

一、实验目的及拓扑 实验目的&#xff1a;构建企业内网和企业分支站点&#xff0c;其中企业内网通过防火墙实现双机热备并且与企业分支固定站点实现站点到站点IPsec VPN互联&#xff0c;与企业分支移动站点实现SSL VPN互联&#xff0c;企业内网各主机可以实现对分支站点内网的…

可观测性(observability)

一、定义 wiki百科的定义 In software engineering, more specifically in distributed computing, observability is the ability to collect data about programs’ execution, modules’ internal states, and the communication among components.[1][2] To improve obser…

8月最新ChatGPT系统源码SparkAi系统,支持AI换脸+智能体GPTs应用+AI绘画+AI视频+文档分析

一、文章序言 人工智能技术正在快速发展&#xff0c;AI语言模型、AI绘画和AI视频已经在多个领域得到了广泛应用。这些技术不仅在科技创新方面表现出色&#xff0c;还在艺术创作、内容生产和商业应用中展示出巨大的潜力。 SparkAi创作系统是一款基于ChatGPT和Midjourney开发的…

矩阵乘法的结合律的证明

矩阵的乘法在矩阵运算中相较于加法更加复杂&#xff0c;对矩阵乘法的运算律的证明也更复杂&#xff0c;但其中对结合律的证明是最难的&#xff0c;因为它涉及到3个矩阵的相乘。本证明不同于其他一些比较粗浅的用方阵去证明或者用三个含很少元素的简单矩阵做一个例证&#xff0c…

App渗透测试(工具使用)

Python工具 在文件中打开终端&#xff0c;执行如下命令进行装库。 python3 -m pip install -r txt文件 执行如下命令扫描 python3 .py -i apk文件

Docker最佳实践(七):安装MinIO文件服务器

大家好&#xff0c;欢迎各位工友。 Minio是一个开源免费的高性能对象存储服务器&#xff0c;专为大规模数据集和高并发访问而设计。它具有出色的读写性能和低延迟&#xff0c;可以满足对数据速度和效率要求较高的应用场景。本篇呢我们就来演示一下如何在Docker中搭建Minio容器&…

MySQL数据库基础:约束

&#x1f48e;我的主页&#xff1a;MySQL &#x1f48e;1. 约束的概述 约束是作用于表中字段的规则&#xff0c;用于限制存储在表中的数据 目的&#xff1a;保证数据库中数据的正确性&#xff0c;有效性和完整性 &#x1f48e;2. 约束的分类 &#x1f48e;2.1 非空约束 非空…

linux之top

要在 Linux 系统上查看 CPU 使用情况&#xff0c;可以使用top命令&#xff1a; 根据您提供的 top 命令的输出&#xff0c;我们可以看到系统的一些基本信息和当前运行的进程。下面是输出的主要部分的解释&#xff1a; 仅供参考&#xff1a; 系统概述: 时间&#xff1a;当前时间…

MATLAB(R和C++)大肠杆菌合成生物机械数学模型

&#x1f3af;要点 &#x1f3af;合成大肠杆菌生物学网络 | &#x1f3af;量化基因型-表型图 | &#x1f3af;化学诱导离散浓度下培养细菌评估整个浓度范围内的表达模式 | &#x1f3af;定性更改合成模型拓扑结构、定量更改相互作用的强度 | &#x1f3af;开发机械数学模型 | …