MySQL面试题 | 10.精选MySQL面试题

news2025/1/12 23:39:20

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

    • 如何使用 GROUP BY 子句和聚合函数?
    • 在上述查询中,如果我想按`order_id`列进行分组,应该如何修改查询语句?
    • 常见的聚合函数代码案例
    • 在 MySQL 中,NULL 和空字符串有什么区别?

如何使用 GROUP BY 子句和聚合函数?

在 MySQL 中,GROUP BY子句用于按照一个或多个列对结果集进行分组,然后可以使用聚合函数对每个组的数据进行聚合计算。

以下是使用GROUP BY子句和聚合函数的一般语法:

SELECT column1, aggregate_function(column2)
FROM table
GROUP BY column1;

在上述语法中,column1是用于分组的列名,可以指定一个或多个列。aggregate_function是一个聚合函数,用于对分组的数据进行计算。

以下是一些常见的聚合函数:

  1. COUNT()函数:用于计算指定列的行数。
  2. SUM()函数:用于计算指定列的总和。
  3. AVG()函数:用于计算指定列的平均值。
  4. MAX()函数:用于找出指定列的最大值。
  5. MIN()函数:用于找出指定列的最小值。

例如,假设有一个orders表包含了订单信息,包括order_idcustomer_idorder_amount列。要按照customer_id列进行分组,并计算每个客户的订单总数量,可以使用以下查询:

SELECT customer_id, SUM(order_amount) AS total_amount
FROM orders
GROUP BY customer_id;

这将返回每个客户的customer_id和对应的订单总数量。

请根据实际需求选择适当的列和聚合函数来进行分组和计算。

在上述查询中,如果我想按order_id列进行分组,应该如何修改查询语句?

如果你想按照order_id列进行分组,并计算每个订单的总数量,可以使用以下查询语句:

SELECT order_id, SUM(order_amount) AS total_amount
FROM orders
GROUP BY order_id;

在这个修改后的查询中,我们将GROUP BY子句中的列名改为order_id,这样查询结果将会按照order_id进行分组,并使用SUM函数计算每个订单的总数量。

常见的聚合函数代码案例

在 MySQL 中,上述提到的部分聚合函数代码案例如下:

  • AVG函数:用于计算指定列的平均值。
    SELECT avg(score) as '平均分' FROM class_score WHERE `subject` = '数学';
    
  • COUNT函数:用于计算符合指定条件的行数,或计算指定列的非空值数量。
    SELECT count(DISTINCT code) as '学生人数' FROM class_score;
    
  • MAX函数:用于找出指定列的最大值。
    SELECT max(score) as '最高分' FROM class_score WHERE `name` = '张山';
    
  • MIN函数:用于找出指定列的最小值。
    SELECT min(score) as '最低分' FROM class_score WHERE `name` = '张山';
    
  • SUM函数:用于计算指定列的总和。
    SELECT sum(score) as '总分' FROM class_score WHERE `name` = '张山';
    

请注意,实际使用中需将表class_score替换为实际的表名,将列subjectcodescore替换为实际的列名,将条件name = '张山’替换为实际的条件。

在 MySQL 中,NULL 和空字符串有什么区别?

在 MySQL 中,NULL和空字符串('')是两个不同的概念。

  • NULL值表示没有值、缺失值或未知值。它用于表示某个列或变量中没有明确的值。当一个列或变量被设置为NULL时,它不表示任何具体的内容。

  • 空字符串是一个包含零个字符的字符串。它与NULL不同,空字符串是一个明确的字符串值,只是它不包含任何字符。

在进行比较或操作时,NULL和空字符串的处理方式也不同:

  • 当比较一个列或变量与NULL值时,结果通常为不确定(除非使用了特殊的比较运算符,如IS NULLIS NOT NULL)。

  • 当比较一个列或变量与空字符串时,通常会将它们视为不同的值。

在数据库设计和编程中,了解NULL和空字符串的区别非常重要,因为它们在查询、连接和其他操作中可能会产生不同的结果。根据具体的需求,你可以选择将列设置为允许NULL值或限制为空字符串。

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

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

相关文章

WinForms TreeView 控件:保持节点选中状态即使失去焦点

WinForms TreeView 控件:保持节点选中状态即使失去焦点 在 Windows 窗体(WinForms)应用程序中,TreeView 控件是一种非常有用的界面元素,允许用户以层次结构的方式浏览信息。然而,一个常见的用户界面问题是&…

关于浮点数的四舍五入问题

最近有关注到,在C/C中,对于浮点数的四舍五入,与实际的有一些出入,我打算今天总结一下,并解释一下这是为啥, 好了,下面进入正题,都是干货哦,认真看完,留下你的…

非常好用的Mac清理工具CleanMyMac X 4.14.7 如何取消您对CleanMyMac X的年度订购

CleanMyMac X 4.14.7是Mac平台上的一款非常著名同时非常好用的Mac清理工具。全方位扫描您的Mac系统,让垃圾无处藏身,您只需要轻松单击2次鼠标左键即可清理数G的垃圾,就这么简单。瞬间提升您Mac速度。 CleanMyMac X 4.14.7下载地址&#xff1a…

Linux Mii management/mdio子系统分析之三 mii_bus注册、注销及其驱动开发流程

(转载)原文链接:https://blog.csdn.net/u014044624/article/details/123303174 本篇是mii management/mdio模块分析的第三篇文章,本章我们主要介绍mii-bus的注册与注销接口。在前面的介绍中也已经说过,我们可以将mii-b…

如何增加服务器的高并发

随着互联网的快速发展和普及,越来越多的应用程序需要支持高并发的请求处理。在这种情况下增加服务器的高并发能力成为了一个热门的话题。下面简单的介绍如果提高服务器的高并发能力。 负载均衡 是把请求分发到多个服务器上,来实现请求的平衡和分担。负…

compose 实验

cd /opt mkdir compose_nginx cd compose_nginx mkdir nginx cd nginx/ 此时顺便将nginx安装包拖进来 vim Dockerfile mkdir /opt/compose_nginx/wwwroot echo "<h1>this is test web</h1>" > /opt/compose_nginx/wwwroot/index.html docker netw…

如何配置mybatisplus基础环境?

1.在pom文件&#xff08;都加上吧&#xff0c;以防万一&#xff09; 2.若当初有mybatis的依赖&#xff0c;要删除 3.在Mapper接口加上"extends BaseMapper<实体类型>" 4.更改yml文件内容 别名扫描包&#xff1a;是指实体类型 5.添加"extends ServiceIm…

SQL语句详解四-DQL(数据查询语言-约束)

约束 概述&#xff1a;对表中的数据进行限定&#xff0c;保证数据的正确性&#xff0c;有效性和完整性。 约束分类 约束关键字约束意思primary key主键约束not null非空约束unique唯一约束foreign key外键约束 例子&#xff1a;sname varchar(40) not null, – 代表 sname 这…

【C语言】指针知识点笔记(2)

目录 一、野指针 二、assert断言 三、指针的使用和传址调用 四、数组名的理解 五、使用指针访问数组 一、野指针 二、assert断言 三、指针的使用和传址调用 四、数组名的理解 五、使用指针访问数组

Web 服务器渗透测试清单

Web 服务器渗透测试在三个重要类别下进行&#xff1a;身份、分析和报告漏洞&#xff0c;例如身份验证弱点、配置错误和协议关系漏洞。 1. “进行一系列有条不紊且可重复的测试”是测试网络服务器是否能够解决所有不同应用程序漏洞的最佳方法。 2.“收集尽可能多的信息”关于…

AtCoder Beginner Contest 336 G. 16 Integers(图计数 欧拉路径转欧拉回路 矩阵树定理 best定理)

题目 给16个非负整数&#xff0c;x[i∈(0,1)][j∈(0,1)][k∈(0,1)][l∈(0,1)] 求长为n3的01串的方案数&#xff0c;满足长度为4的ijkl&#xff08;2*2*2*2&#xff0c;16种情况&#xff09;串恰为x[i][j][k][l]个 答案对998244353取模 思路来源 https://www.cnblogs.com/tz…

多线程并发与并行

&#x1f4d1;前言 本文主要是【并发与并行】——并发与并行的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1f304;每日一句&…

03 顺序表

目录 线性表顺序表练习 线性表(Linear list)是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使用的数据结构&#xff0c;常见的线性表&#xff1a;顺序表、链表、栈、队列、字符串。。。 线性表在逻辑上时线性结构&#xff0c;是连续的一条直线。但在物理结…

【PostgreSQL内核学习(二十一)—— 执行器(InitPlan)】

执行器&#xff08;InitPlan&#xff09; 概述InitPlan 函数代码段解释ExecInitNode 函数 总结 声明&#xff1a;本文的部分内容参考了他人的文章。在编写过程中&#xff0c;我们尊重他人的知识产权和学术成果&#xff0c;力求遵循合理使用原则&#xff0c;并在适用的情况下注明…

力扣每日一练(24-1-16)

我一开始想到的是&#xff0c;如果数字相同则加一。 然而&#xff0c;对了一点点&#xff0c;而已。 高手的方法不是普通人在几分钟内能想得出来的&#xff0c;hh 继续补充&#xff1a; 如果数字不同则减一&#xff0c;如果计数到达了0&#xff0c;则更新数字&#xff0c;最…

【极光系列】springboot集成redis

【极光系列】springboot集成redis tips&#xff1a;主要用于快速搭建环境以及部署项目入门 gitee地址 直接下载源码可用 https://gitee.com/shawsongyue/aurora.git模块&#xff1a;aurora_rediswindow安装redis安装步骤 1.下载资源包 直接下载解压&#xff1a;https://pa…

PHP项目如何自动化测试

开发和测试 测试和开发具有同等重要的作用 从一开始&#xff0c;测试和开发就是相向而行的。测试是开发团队的一支独立的、重要的支柱力量。 测试要具备独立性 独立分析业务需求&#xff0c;独立配置测试环境&#xff0c;独立编写测试脚本&#xff0c;独立开发测试工具。没有…

华硕原厂系统天选5Pro原厂Win11系统恢复安装过程方法

华硕原厂系统天选5Pro原厂Win11系统恢复安装过程方法 华硕原厂系统枪神8/枪神8plus原厂Win11系统恢复安装过程方法 还是老规矩&#xff0c;分3种安装方法 远程恢复安装&#xff1a;https://pan.baidu.com/s/166gtt2okmMmuPUL1Fo3Gpg?pwdm64f 提取码:m64f 支持型号&#x…

new Handler(getMainLooper())与new Handler()的区别

Handler 在Android中是一种消息处理机制。 new Handler(); 创建handler对象&#xff0c;常用在已经初始化了 Looper 的线程中调用这个构造函数&#xff08;即非主线程&#xff09;&#xff0c;如果感觉不好理解&#xff0c;可以把Handler handler new Handler() 理解为常用在…

Vue3中使用自定义指令

一&#xff0c;自定义指令&#xff1a; 应用场景&#xff1a;禁用按钮多次点击 1.vue2 a. src/libs/preventClick.js import Vue from vue const preventClick Vue.directive(preventClick, {inserted: function (el, binding) {el.addEventListener(click, () > {if (!el…