首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

6. SQL 多表查询

前几节所总结的查询,都是基于单张表格进行的,如果单张表格的信息不足以达到查询的目的,就需要将他们组合到一起形成多张表格。 1....首先我们新建一张表,执行如下代码,新建course1表格: DROP TABLE IF EXISTS `course1`; CREATE TABLE `course1` ( `课程号` varchar...course1` VALUES ('0004', '计算机', '0001'); INSERT INTO `course1` VALUES ('0005', '数据库', '0003'); 对于如下图两张表格...2.4 右联结 RIGHT JOIN 右联结和左联结没有什么区别,仅仅是右表数据全部保留,然后对交叉数据进行笛卡尔积,没有的数据用NULL 填充,合并成最终结果。...过程如图所示: MYSQL并不支持全联结,可以通过左右联结加UNION 来实现: 参考《Mysql不支持FULL JOIN怎么办?》 2.6 小结 如图所有联结的小结: 3.

80020

MySQL从入门到入魔(03)

查询工资高于1号部门平均工资的员工信息 select avg(sal) from emp where deptno=1; select * from emp where sal>2325; 把上面两条合并成一条...,A表中1条数据对应B表中的1条数据,同时B表中1条数据也对应A表中的一条数据.称为一对一关系 应用场景: 将原属于一张表的数据拆分成两张表进行数据保存时,使用1对1的关系....(将一张表拆成两张表(主表和从表)) 在从表中添加外键指向主表的主键 一对多:有AB两张表,A表中1条数据对应B表中的多条数据,同时B表中1条数据对应A表中的一条数据.称为一对多关系 应用场景: 比如员工表和部门表的关系...一对多关系中存在两张表,一个表是1(部门表),一个表是多(员工表),在多的表中添加外键指向另外一张表的主键 多对多:有AB两张表,A表中1条数据对应B表中的多条数据,同时B表中1条数据也对应A表中的多条数据...='程序员'; 等值连接和内连接查询到的都是两张表的交集数据,但是内连接代码结构更直观推荐使用 外连接 外连接查询的是一张表的全部和另外一张表的交集数据 格式: select 字段信息 from A left

45110
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    OpenCV-像素运算~逻辑运算

    这里还需要注意两点: 这里所说的像素点,对于单通道来说就是一个数值,而对于三通道的BGR图像来说,通过三个像素点表示图像; 和算术运算一致,要求进行逻辑运算的两张图片必须有相同的shape。...我们不着急解释运算的结果,先来看一个简答的小例子,通过这个小例子,我们就可以知道OpenCV中对两张图片进行逻辑与运算的具体流程。 ?...我们知道在BGR的色彩空间中,三个通道都是0组表示黑色: ? 从表格可以看出,黑色与任何像素点做逻辑与运算的结果都是0,也就是说只要进行逻辑与运算图片中有黑色,那么对应结果肯定为黑色。 ?...只有两张图片对应位置都是黑色的时候结果才为黑色,当某一张图片中为白色的时候,对应逻辑或运算结果也为白色,其余颜色与前面分析相一致。 ? 03 逻辑运算~非 逻辑非运算的规则: ?...从逻辑非中的运算规则中,可以看出此时的逻辑运算只应用在一张图片上。 ? 执行结果: ? 其实对于图像的逻辑运算比较简单,只要知道逻辑运算的规则。

    78920

    Mysql 多表查询详解

    Mysql 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到Mysql中关键字执行的顺序,只涉及了一张表;实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有哪些分类...B)外连接:left join,left outer join,right join,right outer join,union C)交叉连接:cross join 二.下面以实例进行分析 两张假设有两张表格...A和B,把表格当作一个集合,那么表格中的记录就是集合中的一个元素。...两张表格如下: TableA: TableB: 2.1 内连接(只有一种场景) inner join 或者join(等同于inner join) select a.*, b.* from tablea...union join和natural inner join,mysql不支持,而且本身也没有多大意义,其结果可以用上面的几种连接方式得到 总结:总结了mysql所有连接方法,其中有一些是之前没有注意到的问题

    2K20

    MySQL之分库分表(MyCAT实现)

    水平切分:将一张大表按照一定的切分规则,按照行切分到不同的表或者不同的库中。 ? MyCAT介绍 官方网站:http://www.mycat.org.cn/ 什么是MyCAT?...join问题 通过业务分析,将不同库的join查询拆分成多个select 建立全局表(每个库都有一个相同的表) 冗余字段(不符合数据库三范式) E-R分片(将有关系的记录都存储到一个库中) 最多支持跨两张表跨库的...垂直分片:一个数据库中多个表格A,B,C,A存储到节点1上,B存储到节点2上,C存储到节点3上。 ?...MyCAT通过定义表的分片规则来实现分片,每个表格可以捆绑一个分片规则,每个分片规则指定一个分片字段并绑定一个函数,来实现动态分片算法。...Table:表,即物理数据库中存储的某一张表,与传统数据库不同,这里的表格需要声明其所存储的逻辑数据节点DataNode。在此可以指定表的分片规则。

    3.4K30

    表格设计2

    使用自表一对多设计这个表格,因为如果使用多个表格的话,需要增删的情况下就需要改动表格的结构了。所以使用自表一对多的方式,自己这张表的主键对应着自己这张表的外建。 代码示例: ? 例题2: ?...使用多对多的方式设计这个表格一张表存储学生的信息,一张表存储着课程的信息,一张表用于维护表之间的关系。使用多对多的方式是因为维护表格的时候只需要对一张表维护就可以了,就不需要两张表都去维护了。...两张表都得去维护的话,想想也知道维护起来要麻烦得多。 表格示意: ? 代码示例: ? 表格设计: 在sqlyog里我们可以通过此工具设计表格时建立表格之间的映射关系: ?...点击进入此界面后右键选择Add Tables...或者Create Table可以添加表格和创建表格: ? 创建好了两张表: ?...多对多: 多对多的表格设计方式是使用一张关系维护表来维护其他表之间的映射关系。 ?

    52720

    Vue + SpreadJS 实现高性能数据展示与分析

    ,大家有兴趣可以参考虚拟化表格。...SpreadJS如何与Vue3框架继承可参考: Vue3构建电子表格; Vue3集成SpreadJS产品文档。...UI操作上与Excel操作透视表一致,如下所示,我们可以导入一张包含透视数据源的excel文件,之后基于该数据源,选择行列分析维度,生成目标透视表: 怎么样,是不是操作十分简单,秩序简单几步,就可以将...作为前端控件,SpreadJS不会限制接口返回数据来源,可以来自关系型数据库MySQL,SQL Server,也可以来自Redis、Mongodb等其它非关系型数据库,当然,也可以来自OA,CRM等其它业务系统...数据到达前端之后,也可对有关联关系的两张表做连接展示分析,具体操作如下所示: 动图中,演示的两张表对应的数据请求接口分别是: 主表: https://demodata.grapecity.com/

    1.2K40

    第36次文章:数据库查询语句

    在内连接的中,最后显示出来的属于三张表的交集部分,如果有两张表的关联条件不匹配的时候,那么这条记录就不会显示出来。...自连接是将同一张表格当做两张表格来使用,也就是自己与自己进行相互连接。为两张表格起不同的别名。具体的妙处我们通过一个案例来感受一下!...四、from后面 1、特点 将子查询结果充当一张表,要求必须起别名。...tips:在上面的案例中,我们总共分为两步进行查询,第一步查询出每个部门的平均工资之后,mysql中会产生一个虚拟表格,我们需要对这个虚拟表格起一个别名,这样才能够在后续添加连接条件的时候使用到此虚拟表...当我们对第一次产生的虚拟表格起一个别名之后,我们就可以将其放在from后面,作为一张新表,与job_grade表格进行内连接,然后添加相应的连接条件,得到最后的结果。

    1.7K30

    MySQL表分区

    Mysql的一些优化方式: 根据情况更换适当的数据库引擎,一般最好是使用MyISAM引擎,因为是在内存中所以查询速度要比其他引擎快得多。 一张表必须要有主键。...提醒: 在数据量大的表格中查询数据千万不要使用like,也就是模糊查询,或者使用非优化过的列来查询,如果那样做的话查询速度会非常慢。...连接查询: 连接查询分为内连接和外连接,外连接又分为右外连接、左外连接和全外连接,不过在mysql里不支持全外连接的写法。...内连接:就是把两张表的记录进行连接,因为它们有关系的映射,所以连接在一起方便客户的查看。能够使用内连接将两张有关系映射的表的数据符合条件的显示出来,不符合条件的就不显示。

    7.1K20

    用R来拼图和排版,告别AI和PS(一)

    ggplot2) library(patchwork) p1 <- ggplot(mtcars) + geom_point(aes(mpg, disp)) + ggtitle('A') 第一张图...第一行两张图,第二行一张图,—的使用 p1+p2-p3+plot_layout(ncol=1) 会得到下面这张图 这里也可以通过下面的方法实现,条条大路通罗马 (p1+p2)/p3 4.第一行三张图...,第二行一张图,|和/的使用 (p1|p2|p3)/p4 我试了下,好像|换成+也可以。...第一行两张图,第二行两张图 这个其实前面讲过,直接用+就可以实现,接下来我们用/和|来实现 (p1|p2)/(p3|p4) 6.第一列三张图,第二列一张图 (p1/p2/p3)|p4 7.自由发挥...首先图C和图D合并成一列,再和图B并排成一行,然后再和图A合并成一列,就可以得到下面这张图啦!

    68930

    带你学MySQL系列 | 多表连接查询的92语法和99语法,你都知道吗?

    今天我们继续回归带你学MySQL系列,带着大家继续学习MySQL数据库。 多表查询是数据分析师日常工作中一定会使用到的一个知识点,可见它的重要程度有多大。...今天这个文章全面总结了MySQL多表查询的几种情况,你知道MySQL的92语法和99语法吗?你知道等值连接和非等值连接吗?...笛卡尔积现象产生的原因:两张表没有有效的连接条件。...4)自连接:最大特点是,一张表看作两张表。 什么叫做一张表看作两张表呢?也就是说,自连接是同一张表之间的连接,连接条件就是这张表中的不同字段。...AB两张表没有主副之分,两张表是平等的。 ② 外连接 假设A和B表进行连接,使用外连接的话,AB两张表中有一张表是主表,一张表是副表,主要查询主表中的数据,捎带着查询副表。

    92320

    9.MySQL高阶查询方法——聚合查询 联合(多表)查询

    聚合查询 一般需要搭配MySQL中的一些内置“函数” 1)count:用来计算结果的行数 select name,decription from user; +--------+----...| | 刘备 | 仁德之主 | | 孙权 | 年轻有为 | +--------+--------------+ 3 rows in set (0.00 sec) <mysql...联合/多表查询 实现联合查询的基本机制:笛卡尔积 图片 多表查询的过程就是先计算两张表的笛卡尔积,再根据一些条件对笛卡尔积中的记录进行筛选 如果针对两个比较大的表进行联合查询,笛卡尔积的计算开销会很大...student,score,course where student.id = score.student_id and course.id = score.course_id; 2)自连接 自连接是指在同一张表连接自身进行查询...course where (name = '语文' or name = '英文') and course.id = score.course_id); 4)合并查询 相当于把多个表查询的结果集合合并成一个集合

    1.5K40

    MySQL(九)之数据表的查询详解(SELECT语法)二

    上一篇讲了比较简单的单表查询以及MySQL的组函数,这一篇给大家分享一点比较难得知识了,关于多表查询,子查询,左连接,外连接等等。希望大家能都得到帮助!...在开始之前因为要多表查询,所以搭建好环境:   1)创建数据表suppliers   前面已经有一张表是book表,我们在建立一张suppliers(供应商)表和前面的book表对应。   ...其实还有一种自然连接:涉及到的两张表都是同一张表。       举例:查看书id为g2的供应商供应的其他书?        ...四、使用正则表达式查询   使用REGEXP关键字来指定正则表达式,画一张表格,就能将下面所有的度覆盖掉。 ?   ...注意:唯一的差别就在正则表达式不一样,一般使用这种模糊查询,使用MySQL中的'_'和'%'就已经足够了。   2)查询以特定字符或字符串结尾的记录   3)用符号"."

    1.9K100

    用Python测试InnoDB和MyISAM的读写性能

    数据科学俱乐部 中国数据科学家社区 本文测试所用工具版本如下: MySQL:5.7.18 Python:3.6 Pandas:0.23 一、创建数据表 首先我们需要把两张使用了不同引擎的表创建出来,...使用为了方便起见,我们直接使用Navicat创建了两张 员工信息表,具体字段如下: ?...import time db = create_engine('mysql+pymysql://mysql:123456@127.0.0.1:3306/test') start = time.time...结论:多线程的情况下,MyISAM引擎的写入速度比InnoDB引擎的写入速度快42% 四、读取性能对比 为了获得数据量较大的表用于测试数据库的读取性能,我们循环执行10遍上面多线程写入数据的操作,得到两张数据量为...10000条数据的表格,然后读取10遍该表格,获取读取时间 1、InnoDB 引擎 执行以下代码,读取10遍使用了InnoDB引擎的表格 import pandas as pd from sqlalchemy

    1K30
    领券