Mysql:交叉连接、内连接

打开Navicat Premium,新建数据库,创建两个表dept和emp:

create table dept(did int(4) primary key,dname varchar(36));
create table emp(id int(4) primary key,name varchar(36),age int(2),did int(4) not null);

插入数据:
insert into dept values(1,'网络部'),(2,'媒体部'),(3,'研发部'),(4,'人事部');
insert into emp values(1,'刘一',20,1),(2,'陈二',22,1),(3,'张三',20,2),(4,'李四',20,4);

#交叉连接 #行数相乘  列数相加
#select * from 表1 cross join 表2;
select * from dept cross join emp;
select dept.dname,emp.name from dept cross join emp;
#select did from dept cross join emp;  #两个表都有的字段,查询失败
#内连接
#select 查询字段 from 表1 [inner] join 表2 on 表1.关系字段=表2.关系字段;
#内连接使用比较运算符对两个表中的数据进行比较,并列出与连接条件匹配的数据行,组合成新的记录。只有满足条件的记录才能出现在查询结果中
select * from dept join emp on dept.did=emp.did;   #第二个表中的did在字段中变为did(1)
#select emp.name,dept.dname from dept join emp on dept.did=emp.did;
#select name,dname from dept join emp on dept.did=emp.did;
#上边两个表的结果相同,即如果字段名不重复,可以不用表名+字段名,直接使用字段名
select e.name,d.dname from dept as d join emp as e on d.did=e.did;
#使用as给表名命名,以缩短输入
#where条件语句可以替换on实现同样功能
#如:
select * from dept join emp on dept.did=emp.did;
select * from dept,emp where dept.did=emp.did;
#自连接
#如果连接的两个表是同一个表,称为自连接查询
#例:查询与刘一同部门的所有员工的记录
select p1.* from emp p1 join emp p2 on p1.did=p2.did where p2.name='刘一';
#练习:查询与刘一年龄相同的所有员工的姓名
select p1.name from emp p1 join emp p2 on p1.age=p2.age where p2.name='刘一';

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

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

相关文章

spring bean生命周期全部过程

Spring Bean的生命周期包括以下全部过程: 实例化:在Spring容器启动时,根据配置文件或注解等信息创建Bean的实例。属性赋值:如果Bean有属性需要进行初始化,Spring容器会自动为这些属性进行赋值。自定义初始化方法&…

线程理论篇1

本章问题:什么是线程?线程的使用场景?什么是线程池?线程池是如何工作的?线程池共享了哪些资源?线程安全代码怎么写?什么是线程安全? 什么是线程? 线程是为了提高进程的效率。进程的地址空间中保存了cpu…

【mysql】mysql单表查询、多表查询、分组查询、子查询等案例详细解析

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…

嵌入式C语言高级教程:实现基于STM32的人工智能语音识别系统

在嵌入式系统中实现语音识别技术可以极大地增强设备的交互性。本教程将指导您如何在STM32微控制器上使用TensorFlow Lite for Microcontrollers实现基本的语音识别功能。 一、开发环境准备 硬件要求 微控制器:STM32F746NG,支持足够的运算能力和内存来…

spring高级篇(七)

1、异常处理 在DispatcherServlet中,doDispatch(HttpServletRequest request, HttpServletResponse response) 方法用于进行任务处理: 在捕获到异常后没有立刻进行处理,而是先用一个局部变量dispatchException进行记录,然后统一由…

VMware虚拟机中ubuntu使用记录(5)—— 如何在ubuntu中安装USB相机ros驱动并获取usb摄像头数据

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、ROS下USB相机驱动1.准备工作(1) 下载驱动(2) 创建ROS工作空间 2. 安装usb_cam驱动(1) 安装usb_cam驱动包(2) 编译代码 3. 修改usb_cam驱动的配置文件(1) 查看US…

掌握TypeScript的非空断言(!)和可选链(?):开发效率翻倍!

引言 标题:掌握TypeScript的非空断言和可选链:开发效率翻倍!简短介绍:在TypeScript中,?和!操作符是提高代码安全性和开发效率的强大工具。本文将为你揭示它们的使用方式和最佳实践。 背景知识 易于理解的解释&…

vue2+@tinymce/tinymce-vue富文本编辑器的实现

1.使用的第三方的库 npm install @tinymce/tinymce-vue@3.2.8 tinymce@5.10.9 --save 2.引入应用,直接上代码,支持上传图片,视频 <template><div class="tinymce-container" ref="tinymceContainer"><Eidtor api-key="" v-if…

一路串联电机的绕制原理

这里要说明的一点是 对于一路串联的电机&#xff0c;无论是一把线圈还是两把线圈&#xff0c;出来的都是只有两个线头&#xff0c;可看做一个整体来对待&#xff01; 绕制具体原理 同心式线圈绕制 前面说的都是等距式的 线圈绕制&#xff0c;下面我们讲解一下同心式的绕制办法…

numpy学习笔记8

对不同列标识不同信息进行数据读取时 步骤&#xff1a; 1.根据不同列的数据标识的含义和类型&#xff0c;因此需要自定义数据类型 2.使用自定义的数据类型读取数据 有点类似于数据库读取数据操作 例子: # 1. 以上数据由于不同列数据标识的含义和类型不同,因此需要自定义数据类…

整体意义的构成与构建

输入数据中不同部分之间的复杂关系是指数据中各个元素如何相互作用和相互影响以构成整体意义的能力。 理解上述观点可以从以下几个方面进行&#xff1a; 元素的相互作用&#xff1a;在任何给定的数据集中&#xff0c;单个数据元素往往不是孤立存在的。它们之间存在某种形式的交…

692. 前K个高频单词 、KY264 单词识别

692. 前K个高频单词 - 力扣&#xff08;LeetCode&#xff09; //#include<set> class Solution { public://仿函数struct compare{bool operator()(const pair<string,int>& kv1,const pair<string,int>& kv2){return kv1.second > kv2.second;}…

天星金融(原小米金融)持续稳健发展,小米集团2023年质量效益实现双提升

近期&#xff0c;小米集团发布了其2023年财报。数据显示&#xff0c;小米集团在过去的一年里取得了令人瞩目的成绩&#xff0c;总收入达到了2710亿元&#xff0c;经调整后的净利润高达193亿元&#xff0c;同比大增126.3%。 2023年是小米贯彻执行“规模与利润并重”经营策略的第…

##07 从线性回归到神经网络:PyTorch实战解析

文章目录 前言线性回归基础理论背景实现步骤 神经网络介绍理论背景实现步骤 从线性回归到神经网络结论 前言 在深度学习的浩瀚宇宙中&#xff0c;线性回归和神经网络是两个基本但极其重要的概念。线性回归模型是统计学和机器学习的基石之一&#xff0c;而神经网络则是深度学习…

大模型能提高工作效率吗?

大模型可以通过多种方式提高办公效率&#xff0c;尤其是在处理信息和数据方面。 下是一些具体的应用场景&#xff1a; 自动化文档处理&#xff1a; 大模型可以自动处理文档&#xff0c;包括阅读、理解和总结长篇文章或报告&#xff0c;以及自动生成摘要或关键点。 自然语言生…

[开发|鸿蒙] DevEco Studio编译构建(笔记,持续更新)

构建体系 编译构建是将应用/服务的源代码、资源、第三方库等&#xff0c;通过编译工具转换为可直接在硬件设备上运行的二进制机器码&#xff0c;然后再将二进制机器码封装为HAP/APP软件包&#xff0c;并为HAP/APP包进行签名的过程。其中&#xff0c;HAP是可以直接运行在模拟器…

C++算法题 - 二叉树(2)

TOC 114. 二叉树展开为链表 LeetCode_link 给你二叉树的根结点 root &#xff0c;请你将它展开为一个单链表&#xff1a; 展开后的单链表应该同样使用 TreeNode &#xff0c;其中 right 子指针指向链表中下一个结点&#xff0c;而左子指针始终为 null 。展开后的单链表应该与…

2024年全国五大数学建模竞赛Top榜及难度分析!推荐数维杯!!!

发现最近许多同学都陆续开始准备今年的数学建模竞赛了&#xff0c;但是随着数学建模领域越来越普及&#xff0c;影响力越来越广泛&#xff0c;参加的同学也越来越多&#xff0c;就导致有越来越多各式各样的数学建模竞赛此起彼伏出现&#xff0c;但其中有一些竞赛其实并不值得参…

嵌入式学习day13

每日面试题 解释堆和栈的区别 ①申请方式 stack&#xff08;栈&#xff09;&#xff1a;由编译器自带分配释放&#xff0c;存在函数的参数值&#xff0c;局部变量等。 heap&#xff08;堆&#xff09;&#xff1a;程序员自己申请&#xff0c;并指明大小&#xff08;malloc函数…

如何用Jmeter压测

推荐你阅读 互联网大厂万字专题总结 Redis总结 JUC总结 操作系统总结 JVM总结 Mysql总结 微服务总结 互联网大厂常考知识点 什么是系统调用 CPU底层锁指令有哪些 AQS与ReentrantLock原理 旁路策略缓存一致性 Java通配符看这一篇就够 Java自限定泛型 技术分享 如何vscode中刷力扣…