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

在这里插入图片描述

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

文章目录

    • 解释一下连接(JOIN)在 MySQL 中的作用。

解释一下连接(JOIN)在 MySQL 中的作用。

在 MySQL 中,连接(JOIN)用于将两个或多个表中的数据组合在一起,基于它们之间的关联条件

通过连接,你可以在查询中获取相关表中的匹配行,从而能够在结果中显示来自多个表的数据。

以下是连接的一些常见作用:

  1. 获取相关数据:连接允许你从多个表中获取与某个特定主题相关的数据。例如,你可以连接一个客户表和一个订单表,以获取每个客户的订单信息。

  2. 扩展查询结果:通过连接不同的表,你可以在查询结果中添加更多的列和行,提供更全面的信息。

  3. 关联数据:连接用于建立表之间的关系,使得你可以在查询中关联相关的数据。例如,你可以连接一个员工表和一个部门表,以获取每个员工所属部门的信息。

  4. 执行复杂查询:使用连接,你可以执行涉及多个表的复杂查询,获取满足特定条件的相关数据。

MySQL 中,有多种类型的连接可供使用,如

  • 内连接(INNER JOIN)
  • 左连接(LEFT JOIN)
  • 右连接(RIGHT JOIN)
  • 全外连接(FULL OUTER JOIN)

每种连接类型根据不同的需求和关联条件来组合表中的数据。

通过使用连接,你可以将来自不同表的数据关联起来,以便在查询结果中获取更全面和相关的信息。这对于数据分析、报告生成和复杂的数据操作非常有用。

在 MySQL 中,JOIN语句用于将两个或多个表中的数据组合在一起,基于它们之间的关联条件。

以下为你提供一些常见的JOIN类型的代码案例:

  • 笛卡尔积(没有连接条件):
    -- 没有连接条件
    SELECT * FROM user, user_info;
    
    输出结果:
     id | name | id | age ----|------|----|----- 1 | zhangsan | 1 | 20 2 | lisi | 1 | 20 4 | zhaoliu | 1 | 20 1 | zhangsan | 2 | 21 2 | lisi | 2 | 21 4 | zhaoliu | 2 | 21 1 | zhangsan | 3 | 23 2 | lisi | 3 | 23 4 | zhaoliu | 3 | 23 
    
  • 内连接(取交集):
    -- 内连接
    SELECT * FROM user join user_info on user.id = user_info.id;
    
    输出结果:
      id | name | id | age ----|------|----|----- 1 | zhangsan | 1 | 20 2 | lisi | 2 | 21 
    
  • 左外连接(左表数据进行扩充):
    -- 左外连接
    SELECT * FROM user left join user_info on user.id = user_info.id;
    
    输出结果:
      id | name | id | age ----|------|----|----- 1 | zhangsan | 1 | 20 2 | lisi | 2 | 21 4 | zhaoliu | NULL | NULL 
    
  • 左内连接(去掉交集的部分):
    -- 左内连接
    SELECT * FROM user left join user_info on user.id = user_info.id where user_info.id is null;
    
    输出结果:
      id | name | id | age ----|------|----|----- 
    
  • 右外连接(右表数据进行扩充):
    -- 右外连接
    SELECT * FROM user right join user_info on user.id = user_info.id;
    
    输出结果:
      id | name | id | age ----|------|----|----- 
    
  • 右内连接(去掉交集的部分):
    -- 右内连接
    SELECT * FROM user right join user_info on user.id = user_info.id where user.id is null;
    
    输出结果:
      id | name | id | age ----|------|----|----- 
    
  • 全外连接(左连接加右连接去掉共有部分的重复部分):
    -- 全外连接
    SELECT * FROM user a left join user_info b on a.id = b.id 
    UNION 
    SELECT * FROM user a right join user_info b on a.id = b.id;
    
    输出结果:
      id | name | id | age ----|------|----|----- 1 | zhangsan | 1 | 20 2 | lisi | 2 | 21 4 | zhaoliu | NULL | NULL 1 | zhangsan | 2 | 21 2 | lisi | 3 | 23 4 | zhaoliu | NULL | NULL 1 | zhangsan | 3 | 23 2 | lisi | NULL | NULL 
    
  • 自然连接(将两个表中具有相同名称和数据类型的列进行连接):
    -- 自然连接
    SELECT * FROM user natural join user_info;
    
    输出结果:
      id | name | age ----|------|----- 1 | zhangsan | 20 2 | lisi | 21 
    

请注意,上述代码是基于 MySQL 数据库运行,不同的数据库语法略有不同,请根据你的数据库进行调整。

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

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

相关文章

MyBatis-Plus代码生成器使用

这里写目录标题 第一章、添加依赖第二章、准备CodeGenerator类第三章、右键运行main方法 第一章、添加依赖 mybatis-plus-generator依赖和velocity-engine-core依赖和commons-lang3依赖加到pom文件里面&#xff0c;代码生成器会用到 <dependency><groupId>com.bao…

跟着cherno手搓游戏引擎【6】ImGui和ImGui事件

导入ImGui&#xff1a; 下载链接&#xff1a; GitHub - TheCherno/imgui: Dear ImGui: Bloat-free Immediate Mode Graphical User interface for C with minimal dependencies 新建文件夹&#xff0c;把下载好的文件放入对应路径&#xff1a; SRC下的premake5.lua文件&#…

基于STM32F103C8T6单片机的1秒定时器设计与应用

标题&#xff1a;基于STM32F103C8T6单片机的1秒定时器设计与应用 摘要&#xff1a; 本文主要探讨了如何在STM32F103C8T6微控制器上利用内部定时器实现精确的1秒钟定时功能&#xff0c;并通过实际项目实施&#xff0c;验证其稳定性和可靠性。首先介绍了STM32F103C8T6单片机的特…

k8s 存储卷和pvc,pv

存储卷---数据卷 容器内的目录和宿主机的目录进行挂载。 容器在系统上的生命周期是短暂的&#xff0c;deletek8s用控制器创建的pod&#xff0c;delete相当于重启&#xff0c;容器的状态也会回复到初始状态。 一旦回到初始状态&#xff0c;所有的后天编辑的文件的都会消失。 …

Nacos:发现微服务的未来

一、为什么要使用Nacos 在今天的数字化世界中&#xff0c;微服务架构已经成为软件开发的主流。这种架构风格将大型复杂软件拆分为一系列小型的、松耦合的服务&#xff0c;每个服务都可以独立地开发、测试、部署和扩展。然而&#xff0c;随着微服务数量的增长&#xff0c;管理…

SpringBoot教程(十六) | SpringBoot集成swagger(全网最全)

SpringBoot教程(十六) | SpringBoot集成swagger&#xff08;全网最全&#xff09; 一. 接口文档概述 swagger是当下比较流行的实时接口文文档生成工具。接口文档是当前前后端分离项目中必不可少的工具&#xff0c;在前后端开发之前&#xff0c;后端要先出接口文档&#xff0c…

202312 青少年软件编程(C/C++)等级考试试卷(三级)电子学会真题

202312 青少年软件编程&#xff08;C/C&#xff09;等级考试试卷&#xff08;三级&#xff09;电子学会真题 1.因子问题 题目描述 任给两个正整数N、M&#xff0c;求一个最小的正整数a&#xff0c;使得a和(M-a)都是N的因子。 输入 包括两个整数N、M。N不超过1,000,000。 …

Mysql-redoLog

Redo Log redo log进行刷盘的效率要远高于数据页刷盘,具体表现如下 redo log体积小,只记录了哪一页修改的内容,因此体积小,刷盘快 redo log是一直往末尾进行追加,属于顺序IO。效率显然比随机IO来的快Redo log 格式 在MySQL的InnoDB存储引擎中,redo log(重做日志)被用…

C++ 输入用户名和密码 防止注入攻击

1、问题解释&#xff1a;注入攻击 &#xff0c;无密码直接登录数据库 可视化展示 1.1、当你的数据库为&#xff1a;其中包含三个字段id user 以及md5密码 1.2、在使用C堆数据库信息进行访问的时候&#xff0c;使用多条语句进行查询 string sql "select id from t_user…

蓝桥杯基础知识5 unique()

蓝桥杯基础知识5 unique&#xff08;&#xff09; #include <bits/stdc.h>int main(){std::vector<int> vec {1,1,2,2,3,3,3,4,4,5};auto it std::unique(vec.begin(), vec.end());vec.erase(it, vec.end());//vec.erase(unique(vec.begin(),vec.end()),vec.end(…

力扣82-删除排序链表中的重复元素

删除排序链表中的重复元素 题目链接 解题思路 1.遇见相同的元素直接删除即可 2.链表的头部也可能是重复元素&#xff0c;所以需要一个哑节点res来指向链表的头节点 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* List…

机器学习之集成学习概念介绍

概念 机器学习中的集成学习(Ensemble Learning)是一种通过组合多个模型来提高整体性能的技术。它的基本思想是将多个学习器(弱学习器)组合成一个更强大的学习器,以提高整体性能和泛化能力。集成学习可以在各种机器学习任务中使用,包括分类、回归和聚类。 核心 弱学习器…

Spring自带分布式锁你用过吗?

环境&#xff1a;SpringBoot2.7.12 本篇文章将会为大家介绍有关spring integration提供的分布式锁功能。 1. 简介 Spring Integration 是一个框架&#xff0c;用于构建事件驱动的应用程序。在 Spring Integration 中&#xff0c;LockRegistry 是一个接口&#xff0c;用于管理…

使用Postman测试WebService接口

文章目录 使用Postman测试WebService接口1. 访问wsdl地址2. Postman配置1. URL及Headers设置2. Body设置3. 响应结果 使用Postman测试WebService接口 1. 访问wsdl地址 接口地址如&#xff1a;http://localhost:8101/ws/hello?wsdl 2. Postman配置 1. URL及Headers设置 2. B…

跟着小德学C++之数据库基础

嗨&#xff0c;大家好&#xff0c;我是出生在达纳苏斯的一名德鲁伊&#xff0c;我是要立志成为海贼王&#xff0c;啊不&#xff0c;是立志成为科学家的德鲁伊。最近&#xff0c;我发现我们所处的世界是一个虚拟的世界&#xff0c;并由此开始&#xff0c;我展开了对我们这个世界…

【揭秘】sleep()、wait()、park()三种休眠方式的终极对比

在Java中&#xff0c;线程休眠的三种方式包括Thread.sleep、Object.wait和LockSupport.park。Thread.sleep使线程在指定时间后进入休眠&#xff0c;状态为TIMEDWAITING&#xff0c;不会释放锁。Object.wait需在对象锁的保护下调用&#xff0c;会释放该对象的锁&#xff0c;使线…

Java SE入门及基础(13)

流程控制 1. break关键字 应用场景 break只能应用于 while 循环、 do-while 循环、 for 循环和 switch 选择结构 作用 break 应用在循环结构中时&#xff0c;表示终止 break 所在的循环&#xff0c;执行循环结构下面的代码&#xff0c;通常与 if 选择结构配合使用 …

CCS自适应巡航简介-驾驶辅助最初版本

在汽车行业这么多年&#xff0c;接触汽车也有些年头了&#xff0c;最开始接触的驾驶辅助功能就是ACC。 在这里说一说CC的来龙去脉吧~ CCS全称为CRUISE CONTROL SYSTEM&#xff0c;取的是英文首字母。以后看到CCS就要认得这是个啥&#xff1b; 到底有用处呢&#xff0c;如果你…

【ASP.NET Core 基础知识】--中间件--创建自定义中间件

一、为什么需要自定义中间件 自定义中间件在ASP.NET Core中的应用主要有以下几个原因&#xff1a; 满足特定需求&#xff1a; 默认情况下&#xff0c;ASP.NET Core提供了许多内置的中间件来处理常见的任务&#xff0c;如身份验证、授权、静态文件服务等。然而&#xff0c;某些…

leetcode 动态规划(单词拆分)

139.单词拆分 力扣题目链接(opens new window) 给定一个非空字符串 s 和一个包含非空单词的列表 wordDict&#xff0c;判定 s 是否可以被空格拆分为一个或多个在字典中出现的单词。 说明&#xff1a; 拆分时可以重复使用字典中的单词。 你可以假设字典中没有重复的单词。 …