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

news2025/1/19 14:19:59

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过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.coloradmin.cn/o/1384726.html

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

相关文章

Pushmall智能AI数字名片— —SCRM客户资源管理系统

推贴数字AI名片说明: **Pushmall智能AI数字名片:**基于靠谱人脉的地理位置服务,资源查询,数字名片定制服务、企业名片:相互引荐、提供需求;建人脉群、客户群,及简介、短视频、宣传文档、电子图…

Flutter使用stack来实现悬浮UI

文章目录 stack特性示例 stack特性 在Flutter中,你可以使用Stack和Positioned来创建悬浮 UI。Stack允许你将多个小部件叠放在一起,而Positioned则用于定位小部件在Stack中的位置。 示例 以下是一个简单的示例,演示如何创建一个悬浮按钮&am…

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

做过类似的题,一眼就是双指针,刚好也就是题解。 if not nums:return 0p1 0 for p2 in range(1, len(nums)):if nums[p2] ! nums[p1]:p1 1nums[p1] nums[p2]return p1 1 根据规律,重复的数字必定相连,那么只要下一个数字与上一…

Codeforces Round 779 (Div. 2) D2. 388535(思维题 二进制性质/trie树上最大最小异或)

题目 t(t<1e5)组样例&#xff0c;每次给定l,r(0<l<r<2^17) 和r-l1个数ai&#xff0c;新序列是被[l,r]这些数异或上同一个x得到的&#xff0c; 求出x&#xff0c;有多个输出任意一个即可 思路来源 官方题解 洛谷题解 Educational Codeforces Round 157 (Rated…

redis中的string相关的部分命令

redis命令手册 redis中文官网查看文档 挨个进行输出调试 Redis Setnx 命令 Redis Getrange 命令 Redis Mset 命令 redis 127.0.0.1:6379> MSET key1 "Hello" key2 "World" OK redis 127.0.0.1:6379> GET key1 "Hello" redis 127.0.0.1:…

(菜鸟自学)搭建虚拟渗透实验室——安装Kali Linux

安装Kali Linux Kali Linux 是一种基于 Debian 的专为渗透测试和网络安全应用而设计的开源操作系统。它提供了广泛的渗透测试工具和安全审计工具&#xff0c;使安全专业人员和黑客可以评估和增强网络的安全性。 安装KaliLinux可参考我的另一篇文章《Kali Linux的下载安装以及基…

大模型实战05——LMDeploy大模型量化部署实践

大模型实战05——LMDeploy大模型量化部署实践 1、大模型部署背景 2、LMDeploy简介 3、动手实践环节——安装、部署、量化 注 笔记内容均为截图 笔记课程视频地址&#xff1a;https://www.bilibili.com/video/BV1iW4y1A77P/?spm_id_from333.788&vd_source2882acf8c823ce…

等保测评流程是什么样的?测评周期多久?

等保测评流程是什么样的&#xff1f;测评周期多久&#xff1f; 等保测评一般分成五个阶段&#xff0c;定级、备案、测评、整改、监督检查。 1.定级阶段 针对用户的信息系统有等保专家进行定级&#xff0c;一般常见的系统就是三级系统或者是二级系统。在这里有一个小的区分&am…

新年福利大放送-UDS学习宝典

新年福利大放送-UDS学习宝典 小T年末总结 新年伊始&#xff0c;小T首先给大家送上真挚的祝福&#xff1a; 祝大家新年快乐&#xff0c;心想事成&#xff0c;财源广进&#xff0c;永远活出自己最舒服自在的状态&#xff01; 在过去的一年中感谢小伙伴对小T作品的认可与支持&…

通过Wireshark抓包分析谈谈DNS域名解析的那些事儿

原创/朱季谦 本文主要想通过动手实际分析一下是如何通过DNS服务器来解析域名获取对应IP地址的&#xff0c;毕竟&#xff0c;纸上得来终觉浅&#xff0c;绝知此事要躬行。 一、域名与IP地址 当在浏览器上敲下“www.baidu.com”时&#xff0c;一键回车&#xff0c;很快&#x…

财务管理软件,用表格导出账目明细

不论是工资收入&#xff0c;还是日常花销&#xff0c;每一笔钱都需要我们认真对待。然而&#xff0c;许多人在财务管理上仍然采用传统的纸质记账方式&#xff0c;这不仅容易丢失数据&#xff0c;还难以实现财务的统一管理。为此&#xff0c;我为大家推荐一款简单好用的记账软件…

基于深度学习的多类别电表读数识别方案详解

基于深度学习的多类别电表读数识别方案详解 多类别电表读数识别方案详解项目背景项目难点最终项目方案系列项目全集&#xff1a; 安装说明环境要求 数据集简介数据标注模型选型明确目标&#xff0c;开始下一步的操作 检测模型训练模型评估与推理番外篇&#xff1a;基于目标检测…

linux Tcp总结

Tcp连接建立时的影响因素 在Client发出SYN后&#xff0c;如果过了1秒 &#xff0c;还没有收到Server的响应&#xff0c;那么就会进行第一次重传&#xff1b;如果经过2s的时间还没有收到Server的响应&#xff0c;就会进行第二次重传&#xff1b;一直重传tcp_syn_retries次。 对…

无公网ip如何随时随地远程查看本地群晖NAS存储的文件资源

文章目录 前言本教程解决的问题是&#xff1a;按照本教程方法操作后&#xff0c;达到的效果是前排提醒&#xff1a; 1. 搭建群晖虚拟机1.1 下载黑群晖文件vmvare虚拟机安装包1.2 安装VMware虚拟机&#xff1a;1.3 解压黑群晖虚拟机文件1.4 虚拟机初始化1.5 没有搜索到黑群晖的解…

python -- pyQt5中 样式设置

一、父控件设置样式表后对子控件产生影响&#xff0c;控制styleSheet的作用范围 https://blog.csdn.net/qq_31073871/article/details/90288625 QFrame 作为容器&#xff0c;放入其他多种部件&#xff0c;里面的边框都生效 在类名后面用 #号串接变量名&#xff0c;子控件不…

浅学Linux之旅 day1 学习路线及计算机入门知识介绍

我不要做静等被掀起的轻波&#xff0c;我要生起翠绿的斑驳 偶尔过季的遭遭人事化长风拂过 思绪撕碎点燃了火 ——24.1.14 一、Linux学习路线 ①计算机入门知识介绍 ②Linux系统概述 ③Linux系统的安装和体验 ④Linux的网络配置和连接工具 ⑤Linux的目录结构 ⑥Linux的常用命令 …

Qt/QML编程学习之心得:小键盘keyboard(36)

小键盘对于qml应用是经常用到的,在qml里面,就如一个fileDialog也要自己画一样,小键盘keyboard也是要自己画的,对于相应的每个按键的clicked都要一一实现的。 这里有一个示例: 代码如下: import QtQuick 2.5 import QtQuick.Controls 1.4 import QtQuick.Window 2.0 im…

五种嵌入式经典通信总线协议

一.先前知识 1.并行与串行 并行通信和串行通信是两种不同的数据传输方式&#xff1a; 并行通信&#xff1a;并行通信是指在同一时间使用多条并行传输的线路传输多个比特的数据。每个比特使用独立的线路进行传输&#xff0c;同时进行。这样可以在一个时钟周期内传输多个比特&…

Kafka消费全流程

Kafka消费全流程 1.Kafka一条消息发送和消费的流程图(非集群) 2.三种发送方式 准备工作 创建maven工程&#xff0c;引入依赖 <dependency><groupId>org.apache.kafka</groupId><artifactId>kafka-clients</artifactId><version>3.3.1&l…

阿里云服务器的tcp端口无法访问(云服务厂家问题?)

问题->无法访问 阿里云服务器的tcp端口 最近一台阿里云服务器的一个端口61616无法访问&#xff0c;在服务器内用外网地ip发现无法访问&#xff0c;用内网ip访问是正常的&#xff0c;通过技术排查&#xff1a; 解决->无法访问 阿里云服务器的tcp端口 1 配置官网的安全组…