mysql的查询操作

news2024/9/25 10:38:23

MySQL的查询操作是数据库管理和数据检索的核心。通过SQL(Structured Query Language,结构化查询语言)语句,用户可以执行包括数据检索、数据插入、更新和删除在内的多种操作。在本文中,我们将重点讨论数据检索(即SELECT语句)的高级用法和最佳实践。

一、基础查询
  • SELECT语句的基本结构

    • SELECT column1, column2, ...
    • FROM table_name;

    这个结构用于从指定表中选取一列或多列的数据。

  • WHERE子句

    • SELECT column1, column2, ...
    • FROM table_name
    • WHERE condition;

    WHERE子句用于过滤记录,仅返回满足条件的记录。

  • ORDER BY子句

    • SELECT column1, column2, ...
    • FROM table_name
    • ORDER BY column_name [ASC|DESC];

    ORDER BY子句用于对查询结果进行排序。

二、高级查询技巧
1. 聚合函数

MySQL提供了多种聚合函数,如COUNT(), SUM(), AVG(), MAX(), MIN()等,用于对一组值执行计算并返回单个值。

  • 示例:计算表中记录的总数。
    SELECT COUNT(*) FROM table_name;
2. 分组查询(GROUP BY)

GROUP BY子句用于结合聚合函数,将结果集按照一个或多个列进行分组。

  • 示例:按部门分组计算每个部门的员工数量。
    SELECT department, COUNT(*) as employee_count  
    FROM employees  
    GROUP BY department;
3. HAVING子句

HAVING子句用于对GROUP BY产生的分组进行条件过滤,其用法与WHERE子句类似,但HAVING子句在数据分组后进行过滤。

  • 示例:筛选出员工数量大于10的部门。
    SELECT department, COUNT(*) as employee_count  
    FROM employees  
    GROUP BY department  
    HAVING COUNT(*) > 10;
4. 连接查询(JOIN)

连接查询用于从两个或多个表中根据连接条件查询数据。MySQL支持多种类型的连接,包括内连接(INNER JOIN)、左连接(LEFT JOIN)、右连接(RIGHT JOIN)等。

  • 示例:查询员工及其所在部门的信息(使用内连接)。

    SELECT employees.name, departments.name AS department_name  
    FROM employees  
    INNER JOIN departments ON employees.department_id = departments.id;
5. 子查询

子查询是嵌套在其他查询中的查询。子查询可以用在SELECT、FROM、WHERE等子句中。

  • 示例:查询薪资高于公司平均水平的员工。

    SELECT *  
    FROM employees  
    WHERE salary > (SELECT AVG(salary) FROM employees);
6. 窗口函数(MySQL 8.0+)

窗口函数(也称为分析函数)提供了一种在结果集的行上执行计算的方式,而不需要将行组合成多个输出行。常见的窗口函数有ROW_NUMBER(), RANK(), DENSE_RANK(), SUM() OVER(), AVG() OVER()等。

  • 示例:为员工薪资排名。
    SELECT name, salary,  
           RANK() OVER (ORDER BY salary DESC) AS salary_rank  
    FROM employees;
三、查询优化

查询优化是提高数据库性能的关键。以下是一些常见的优化策略:

  1. 索引优化:合理使用索引可以显著提高查询速度。但过多的索引会减慢数据插入、更新和删除的速度,并增加存储需求。

  2. 查询重写:避免在WHERE子句中使用函数或计算,因为这会使索引失效。尽量将复杂的查询分解为简单的子查询。

  3. 减少数据传输:只查询需要的列,避免使用SELECT *。使用LIMIT子句限制返回的行数,特别是当查询结果集很大时。

  4. 避免全表扫描:确保WHERE子句中的条件能够利用索引,从而避免全表扫描。

  5. 使用EXPLAIN计划:MySQL的EXPLAIN命令可以显示MySQL如何执行SELECT语句,包括是否使用了索引,连接类型等,是查询优化的重要工具。

  6. 查询缓存(注意:MySQL 8.0起已弃用查询缓存):虽然MySQL提供了查询缓存功能,但在高并发场景下,查询缓存的维护成本可能很高,且不一定能带来性能提升。

  7. 服务器和硬件优化:增加CPU、内存和更快的存储系统(如SSD)可以显著提高数据库的性能。

四、最佳实践
  1. 编写清晰、可维护的SQL代码:使用有意义的别名、格式化SQL语句、避免在SQL代码中硬编码值。

  2. 避免过度设计:不要为了未来的可能需求而过度设计数据库和查询。根据当前的需求和预期的增长来设计。

  3. 定期审查和维护:定期审查数据库的性能,更新统计信息,重新组织表,删除无用的索引等。

  4. 使用参数化查询:防止SQL注入攻击,提高代码的安全性。

  5. 备份和恢复计划:制定并定期测试数据库的备份和恢复计划,确保在数据丢失或损坏时能够快速恢复。

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

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

相关文章

每日论文1——应用于65nm CMOS锁相环完全电流匹配的电荷泵

《A Charge Pump with Perfect Current Matching Applied to Phase-Locked Loop in 65nm CMOS》2021 IEEE 14th International Conference on ASIC 电荷泵PLL的结构框图如图,其中CP的充放电电流不匹配会引起PLL的频率误差和杂散。 传统的电荷泵结构在输出处的电平…

强烈推荐的10款企业文件加密软件|2024企业办公文件加密

随着信息安全威胁的不断增加,企业文件加密成为保护敏感数据的重要手段。在2024年,有多款文件加密软件可供选择,帮助企业提高数据安全性。以下是十款强烈推荐的企业文件加密软件。 1.安秉加密软件 安秉加密软件专为企业设计,主要用…

【Web】初识Web和Tomcat服务器

目录 前言 一、认识web 1. 软件架构模式 2. web资源 3. URL请求路径(统一资源定位符) 二、Tomcat服务器 1. 简介 2. tomcat服务器的目录结构 3.使用tomcat服务器启动失败的常见原因 3.1 端口冲突 3.2 jdk环境变量配置出错 三、使用Tomcat发布…

OpenSSH9.7升级至OpenSSH9.9(openssh7以后所有版本升级均可使用该方法)

1、查看当前openssh版本,使用命令ssh -V 2、开启当前主机的telnet和ftp service xinetd start #开启telnetservice vsftpd start #开启ftp 3、下载openssh最新版 下载地址: OPENSSH下载地址https://cdn.openbsd.org/pub/OpenBSD/OpenSSH/portable/ 4、开始安…

【Redis入门到精通五】Java如何像使用MySQL一样使用Redis(jedis安装及使用)

目录 Jedis 1.jedis是什么 2.jedis的安装配置 3.jedis的基础命令操作展示 1.set和get操作: 2.exists和del操作: 3.keys和type操作: 4. expire和ttl: Jedis Java 操作 redis 的客⼾端有很多,其中最知名的是 jedi…

大模型备案和互联网算法备案的区别?

最近,接到很多客户的电话咨询大模型备案和互联网算法备案,好多人搞不清楚这两个有什么关系?有什么区别?我们先来看下全国大模型备案和互联网算法备案通过的情况是怎么样的? 截至写稿之时,全国通过大模型备…

2024最新最全【Qubes Linux系统安装下载】零基础入门到精通!

Qubes Linux的安装和设置过程非常简单。它也是一个以安全为中心的桌面操作系统,旨在通过隔离提供安全性,这对于系统管理员、记者和有道德的黑客来说是一个很好的卖点。 Qubes是一个使用Xen的 Linux 发行版,这是一种虚拟化技术,它…

卫星图片地面目标识别检测数据集 1500张 yolo数据集 已增强

卫星图像地面目标识别数据集(Satellite Image Ground Target Recognition Dataset, SIGTRD) 摘要 SIGTRD 是一个专门为卫星图像中的地面目标识别而设计的数据集,它包含了一系列常见的基础设施和交通工具类型。该数据集提供了1500张卫星图像…

基于单片机的指纹打卡系统

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于STC89C52RC,采用两个按键替代指纹,一个按键按下,LCD12864显示比对成功,则 采用ULN2003驱动步进电机转动,表示开门,另一个…

电脑桌面归纳小窗口如何设置?电脑桌面一键整理工具分享!

电脑桌面归纳小窗口如何设置?日常使用电脑的过程中,随着文件、应用程序的不断增加,桌面往往会变得杂乱无章,这不仅影响了美观,也降低了工作效率。幸运的是,现代技术为我们提供了多种桌面整理工具&#xff0…

【QA-MISRA】解决使用命令行扫描项目后看不到报告的问题

1、 文档目标 解决使用命令行扫描项目后看不到报告的问题 2、 问题场景 客户使用命令行扫描项目后看不到报告,原因是客户未设置和勾选报告格式就导出了DAX文件进行命令行直接扫描。 3、软硬件环境 1、软件版本: QA-MISRA23.04 2、机器环境&#xff1…

李宏毅2023机器学习作业HW07解析和代码分享

ML2023Spring - HW7 相关信息: 课程主页 课程视频 Kaggle link 回来了 : ) Sample code HW07 视频 HW07 PDF 个人完整代码分享: GitHub | Gitee | GitCode P.S. HW7 的代码都很易懂,可以和 2024 年的新课:生成式AI导论做一个很好的衔接&#…

开源 AI 智能名片与 S2B2C 商城小程序:嫁接权威实现信任与增长

摘要:本文探讨了嫁接权威在产品营销中的重要性,并结合开源 AI 智能名片与 S2B2C 商城小程序,阐述了如何通过与权威关联来建立客户信任,提升产品竞争力。强调了在当今商业环境中,巧妙运用嫁接权威的方法,能够…

一款前后端分离设计的企业级快速开发平台,支持单体服务与微服务之间灵活切换(附源码)

前言 当前软件开发面临诸多挑战,诸如开发效率低下、重复工作多、维护成-本高等问题,这些问题在一定程度上阻碍了项目的进展。针对这些痛点,我们迫切需要一款既能提升开发效率又能降低维护成-本的处理方案。由此,一款基于前后端分…

HDMI20协议解析_Audio_Clock_Regeneration

HDMI20协议解析_Audio_Clock_Regeneration 1.版本说明 日期作者版本说明20240918风释雪初始版本 2.概述 当通过HDMI传输音频信号时,Audio Clock Regeneration(ACR)是必须要传输的数据包之一; HDMI传输过程中,音频采样…

数学建模-线性规划讲解(Matlab版本)

引言 相信不少小伙伴刚开始接触数学建模时,第一个学习的算法就是运筹学的重要分支--数学规划,而数学规划当中重要的分支就是线性规划了。在这里笔者参考了司守奎和孙玺菁老师的《数学建模算法与应用》(第三版)这本书,以此来讲讲关…

同等学力申硕英语多少分及格

同等学力申硕全国统考与往年的分数线一样,英语、学科综合均为60分合格通过制,满分均100分。 单科分数未达到及格线的考生,次年5月可以参加单科的补考 同等学力申硕的意义和作用 授予同等学力人员硕士学位是国家为同等学力人员开辟的获得学位…

前端——阿里图标的使用

阿里图标 将小图标定义成字体,通过引入字体的方式来展示这些图标 1.打开阿里图标库 https://www.iconfont.cn/ 2.登录 / 注册一个账号 3.选中你需要使用的图标 并且把它加入购物车 4.全部选择完之后 点击右上角 购物车 然后下载代码 5.解压后你下载的文…

MySQL数据库的日志你知道几个?

1、前言 MySQL相信大家都用过,但MySQL中都有哪些日志,是干什么的,估计有小伙伴还没有搞清楚。可能有小伙伴只知道最重要的三个:undolog、redolog、binlog。其实这是不全的,MySQL中的日志有: undolog&…

双端搭建个人博客

1. 准备工作 确保你的两个虚拟机都安装了以下软件: 虚拟机1(Web服务器): Apache2, PHP虚拟机2(数据库服务器): MariaDB2. 安装步骤 虚拟机1(Web服务器) 安装Apache2和PHP 更新系统包列表: sudo apt update安装Apache2: sudo apt install apache2 -y安装PHP及其Apac…