【MySQL】学习多表查询和笛卡尔积 - 副本

](https://img-blog.csdnimg.cn/21dd41dce63a4f2da07b9d879ad0120b.png#pic_center)

??个人主页:
??热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法
??个人格言:“没有罗马,那就自己创造罗马~”

#mermaid-svg-N8PeTKG6uLu4bJuM {font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-N8PeTKG6uLu4bJuM .error-icon{fill:#552222;}#mermaid-svg-N8PeTKG6uLu4bJuM .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-N8PeTKG6uLu4bJuM .edge-thickness-normal{stroke-width:2px;}#mermaid-svg-N8PeTKG6uLu4bJuM .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-N8PeTKG6uLu4bJuM .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-N8PeTKG6uLu4bJuM .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-N8PeTKG6uLu4bJuM .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-N8PeTKG6uLu4bJuM .marker{fill:#333333;stroke:#333333;}#mermaid-svg-N8PeTKG6uLu4bJuM .marker.cross{stroke:#333333;}#mermaid-svg-N8PeTKG6uLu4bJuM svg{font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-N8PeTKG6uLu4bJuM .label{font-family:“trebuchet ms”,verdana,arial,sans-serif;color:#333;}#mermaid-svg-N8PeTKG6uLu4bJuM .cluster-label text{fill:#333;}#mermaid-svg-N8PeTKG6uLu4bJuM .cluster-label span{color:#333;}#mermaid-svg-N8PeTKG6uLu4bJuM .label text,#mermaid-svg-N8PeTKG6uLu4bJuM span{fill:#333;color:#333;}#mermaid-svg-N8PeTKG6uLu4bJuM .node rect,#mermaid-svg-N8PeTKG6uLu4bJuM .node circle,#mermaid-svg-N8PeTKG6uLu4bJuM .node ellipse,#mermaid-svg-N8PeTKG6uLu4bJuM .node polygon,#mermaid-svg-N8PeTKG6uLu4bJuM .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-N8PeTKG6uLu4bJuM .node .label{text-align:center;}#mermaid-svg-N8PeTKG6uLu4bJuM .node.clickable{cursor:pointer;}#mermaid-svg-N8PeTKG6uLu4bJuM .arrowheadPath{fill:#333333;}#mermaid-svg-N8PeTKG6uLu4bJuM .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-N8PeTKG6uLu4bJuM .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-N8PeTKG6uLu4bJuM .edgeLabel{background-color:#e8e8e8;text-align:center;}#mermaid-svg-N8PeTKG6uLu4bJuM .edgeLabel rect{opacity:0.5;background-color:#e8e8e8;fill:#e8e8e8;}#mermaid-svg-N8PeTKG6uLu4bJuM .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-N8PeTKG6uLu4bJuM .cluster text{fill:#333;}#mermaid-svg-N8PeTKG6uLu4bJuM .cluster span{color:#333;}#mermaid-svg-N8PeTKG6uLu4bJuM div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-N8PeTKG6uLu4bJuM :root{–mermaid-font-family:“trebuchet ms”,verdana,arial,sans-serif;}

at one time ‘曾经,一度,同时’

文章目录
  • `多表查询`
  • `多表查询分类`
    • `连接查询`
      • 内连接:
      • 外连接:
      • 自连接:
    • `字查询`
  • `总结`

多表查询

指的是从多张表中查询数据

  • 首先准备好需要查询的数据表 - dept表 和 emp表

    – 准备数据
    create table dept(
    id int auto_increment comment ‘ID’ primary key ,
    name varchar(50) not null comment ‘部门名称’
    )comment ‘部门表’;
    insert into dept(id, name) VALUES (1,‘研发部’),(2,‘市场部’),(3,‘财务部’),(4,‘销售部’),(5,‘总经办’),(6,‘人事部’);

    create table emp(
    id int auto_increment comment ‘ID’ primary key ,
    name varchar(50) not null comment ‘姓名’,
    age int comment ‘年龄’,
    job varchar(20) comment ‘职位’,
    salary int comment ‘薪资’,
    entrydate date comment ‘入职时间’,
    managerid int comment ‘直属领导ID’,
    dept_id int comment ‘部门ID’
    )comment ‘员工表’;

    insert into emp (id, name, age, job, salary, entrydate, managerid, dept_id) VALUES
    (1,‘金庸’,66,‘总裁’,2000,‘2000-01-01’,null,5),(2,‘张无忌’,20,‘项目经理’,12500,‘2005-12-05’,1,1),
    (3,‘杨逍’,33,‘开发’,8400,‘2000-11-03’,2,1),(4,‘韦一笑’,48,‘开发’,11000,‘2002-02-05’,2,1),
    (5,‘常遇春’,43,‘开发’,10500,‘2004-09-07’,3,1),(6,‘小昭’,19,‘程序员鼓励师’,6600,‘2004-10-12’,2,1),
    (7,‘灭绝’,60,‘财务总监’,8500,‘2002-09-12’,1,3),(8,‘周芷若’,19,‘会计’,48000,‘2006-06-02’,7,3),
    (9,‘丁敏君’,23,‘出纳’,5250,‘2009-05-13’,7,3),(10,‘赵敏’,20,‘市场部总监’,12500,‘2004-10-12’,1,2),
    (11,‘鹿杖客’,56,‘职员’,3750,‘2006-10-03’,10,2),(12,‘鹤笔翁’,19,‘职员’,3750,‘2007-05-09’,10,2),
    (13,‘方东白’,19,‘职员’,5500,‘2009-02-12’,10,2),(14,‘张三丰’,88,‘销售总监’,14000,‘2004-10-12’,14,4),
    (15,‘俞莲舟’,38,‘销售’,4600,‘2004-10-12’,14,4),(16,‘宋远桥’,40,‘销售’,4600,‘2004-10-12’,14,4),
    (17,‘陈友谅’,42,null,2000,‘2011-10-12’,1,null);

    – 添加外键将两张表进行关联
    alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);

在这里插入图片描述
在这里插入图片描述

-- 多表查询 - 笛卡尔积
select * from emp , dept ;

在这里插入图片描述

  • 笛卡尔积:笛卡尔乘积是指在数学中,两个集合 A 集合和 B集合的所有组合情况。(在多表查询时,需要消除无效的笛卡尔积)—>17*6 = 102 所以我们可以看到102条记录
    在这里插入图片描述

如何消除无效的笛卡尔积?

我们可以通过emp表中的外键和dept的id建立连接,我们只需要在原来基础上加上条件即可

-- 多表查询 - 通过where添加条件,消除无效的笛卡尔积
select * from emp , dept where emp.dept_id = dept.id ;

在这里插入图片描述

通过控制台运行结果我们可以发现我们明明有17个员工而查询到的结果只有16条,这是为什么呢? 这是因为我们的陈友谅这个员工是刚来的员工还没有给他分配部门。??

在这里插入图片描述

多表查询分类

连接查询

内连接:

相当于查询A、B交集部分数据

外连接:

左外连接:查询 左表 所有数据,以及两张表交集部分数据

右外连接:查询 右表 所有数据,以及两张表交集部分数据

自连接:

当前表与自身的连接查询,自连接必须使用表别名。

字查询

在这里插入图片描述

总结

在这里插入图片描述
](https://img-blog.csdnimg.cn/0ee6c4ec414740b0a0404c5161cdadc7.gif#pic_center)

](https://img-blog.csdnimg.cn/cc002cbd5c414c5393e19c5e0a0dbf20.gif#pic_center#pic_center)

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

强化学习Agent系列(二)——PyGame虚拟环境创建与Python 贪吃蛇Agent制作实战教学

文章目录 一、前言二、gymnasium 简单虚拟环境创建1、gymnasium介绍2、gymnasium 贪吃蛇简单示例 三、基于gymnasium创建的虚拟环境训练贪吃蛇Agent1、虚拟环境2、虚拟环境注册3、训练程序4、模型测试 三、卷积虚拟环境1、卷积神经网络虚拟环境2、训练代码 一、前言 大家好&am…

300分钟吃透分布式缓存(拉钩教育总结)

开篇寄语 开篇寄语:缓存,你真的用对了吗? 你好,我是你的缓存老师陈波,可能大家对我的网名 fishermen 会更熟悉。 我是资深老码农一枚,经历了新浪微博从起步到当前月活数亿用户的大型互联网系统的技术演进…

NebulaGraph入门

感谢阅读 官方文档链接NebulaGraph简介nGQLnGQL简介占位标识符和占位符值注释实列大小写区分关键字 基本概念以及相关代码实现补充说明图空间语法以及列子创建克隆官方示例代码(创建并克隆)USE语句指定图空间时查看所有SPACESPACE详情CLEAR SPACE删库跑路(看玩笑的说…

C语言:字符函数 字符串函数 内存函数

C语言:字符函数 & 字符串函数 & 内存函数 字符函数字符分类函数字符转换函数tolowertoupper 字符串函数strlenstrcpystrcatstrcmpstrstrstrtok 内存函数memcpymemmovememsetmemcmp 字符函数 顾名思义,字符函数就是作用于字符的函数,…

3dgs学习(二)—— 3d高斯与协方差矩阵及其几何意义

协方差矩阵与3d高斯 3d高斯与椭球与协方差矩阵 3d高斯,及3维空间内的正态分布。 通过一元正态分布的坐标系图像不难想象,3维空间中的正态分布点集中在一片椭球空间中,各方向长轴取决于各方向正态分布的方差。 而协方差矩阵通过计算多元之…

好物周刊#42:国产项目管理软件

https://github.com/cunyu1943 村雨遥的好物周刊,记录每周看到的有价值的信息,主要针对计算机领域,每周五发布。 一、项目 1. 菠萝博客 基于 Java 的菠萝博客系统,简单易部署,精致主题,贴心服务&#xf…

本届挑战赛亚军方案:面向微服务架构系统中无标注、多模态运维数据的异常检测、根因定位与可解释性分析

CheerX团队来自于南瑞研究院系统平台研发中心,中心主要从事NUSP电力自动化通用软件平台的关键技术研究与软件研发。 选题分析 图1 研究现状 本次CheerX团队的选题紧密贴合了目前的运维现状。实际运维中存在多种问题导致运维系统的不可用。比如故障发生时&#xff…

【常用】【测速】ptflops库---速度FPS、参数Params、计算复杂度Flops

一、常用名字 中文名字 英文名字 简称 单位 模型参数量 number of parameters. param. (单位B M) 计算复杂度 computational…

【Spring Cloud 进阶】OpenFeign 底层原理解析

参考文章 万字33张图探秘OpenFeign核心架构原理 | 三友SpringCloud OpenFeign源码详细解析Java 代理机制 OpenFeign 是一个精彩的使用动态代理技术的典型案例,通过分析其底层实现原理,我们可以对动态代理技术有进一步的理解。 目录 1. Feign 与 OpenFeig…

VUE3:统计分析页面布局+自适应页面参考

一、布局 <template><div class"container1"><div class"form white"><el-form :inline"true" :rules"rules" :model"queryParams" label-width"80px" ref"querParmRef"><e…

力扣递归:路径总和

思路&#xff1a;此题思路为递归实现&#xff0c;递归思路为&#xff1a;在每层递归的过程中将各个节点的数据记录下来&#xff0c;不断将减少目标数据的值准备进行判断&#xff0c;当进行到叶子节点时要进行判断 /*** Definition for a binary tree node.* struct TreeNode {…

OJ_二叉树最短路径长度

题干 C实现 #define _CRT_SECURE_NO_WARNINGS #include<iostream> #include<vector> using namespace std;struct TreeNode {int num;TreeNode* left;TreeNode* right;TreeNode* parent; };void createTree(vector<TreeNode*>& nodeArr, int n) {for (i…

2000-2022年上市公司绿色专利申请占比/数据

2000-2022年上市公司绿色专利申请占比数据 1、时间&#xff1a;2000-2022年 2、来源&#xff1a;国家知识产权局、WIPO绿色专利清单 3、指标&#xff1a;年份、股票代码、股票简称、行业代码、省份、城市、区县、行政区划代码、城市代码、区县代码、首次上市年份、上市状态、…

又降价啦!2024年阿里云核心产品价格全线下调,最高幅度达55%

2024年3月1日开始&#xff0c;阿里云将开启新一轮的降价政策&#xff0c;核心产品价格全线下调&#xff0c;平均降幅20%&#xff0c;最高幅度达55%&#xff0c;阿里云希望通过此次大规模降价&#xff0c;让更多企业和开发者用上先进的公共云服务&#xff0c;加速云计算在中国各…

深度学习 精选笔记(8)梯度消失和梯度爆炸

学习参考&#xff1a; 动手学深度学习2.0Deep-Learning-with-TensorFlow-bookpytorchlightning ①如有冒犯、请联系侵删。 ②已写完的笔记文章会不定时一直修订修改(删、改、增)&#xff0c;以达到集多方教程的精华于一文的目的。 ③非常推荐上面&#xff08;学习参考&#x…

备战蓝桥杯Day19 - 堆排序基础知识

一、每日一题 - 填充 详细题解 s input() # 输入字符串 n len(s) # 定义字符的长度 judge ["00", "11", "0?", "1?", "?0", "?1", "??"] # 把所有的情况一一列举出来 count 0 # 设置计数…

【Python】PyGameUI控件

哈里前段时间写了一个windows平板上自娱自乐&#xff08;春节和家人一起玩&#xff09;基于pygame的大富翁游戏。 pygame没有按钮之类的UI控件&#xff0c;写起来不怎么顺手。就自己写一个简单的框架。 仓库地址 哈里PygameUi: pygame ui封装自用 (gitee.com) 使用示例 示…

Tomcat 软件和配置文件 基本介绍

一 &#xff0c;web知识 简介 &#xff08;一&#xff09;web技术 1&#xff0c;http协议和 B/S &#xff08;Browser/Server&#xff09;结构 最早出现了CGl (Common Gateway Interface)通用网关接口&#xff0c;通过浏览器中输入URL直接映射到一个服务器端的脚本程序执行&…

从单体服务到微服务:多模式 Web 应用开发记录<三>预初始化属性

相关文章&#xff1a; 多模式 Web 应用开发记录<一>背景&全局变量优化多模式 Web 应用开发记录<二>自己动手写一个 Struts 开头先看一个简单的例子&#xff0c;这是 ftl 文件的一个表单&#xff1a; <form id"validateForm" action"#&quo…

【程序员是如何看待“祖传代码”的?】《代码的遗产:探索程序员眼中的“祖传代码”》

程序员是如何看待“祖传代码”的&#xff1f; 在程序员的世界里&#xff0c;代码不仅仅是构建软件的基石&#xff0c;它们也承载着历史、智慧和技术的演变。在我的编程生涯中&#xff0c;我遇到过许多神奇而独特的“祖传代码”&#xff0c;这些代码如同古老的魔法书&#xff0…