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

⑧【MySQL】数据库查询:内连接、外连接、自连接、子查询、多表查询

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ 内连接、外连接、自连接...多表查询 多表查询: 在多张表中查询数据。 笛卡尔积:两个集合,集合A 与 集合B中元素的所有组合情况,在多表查询时需要使用WHERE关键字或 JOIN ON关键字消除笛卡尔积。...—— LEFT OUTER JOIN 连接查询 —— 左外连接: 外连接 —— 左外连接: ①查询表1所有数据,包含表1和表2交集部分的数据。...`id`; 右外连接 —— RIGHT OUTER JOIN 连接查询 —— 右外连接 外连接 —— 右外连接: ①查询表2所有数据,包含表1和表2交集部分的数据。...`id`; 自连接 —— JOIN 连接查询 —— 自连接: 自连接: ①自连接查询,可以是内连接查询,也可以是外连接查询 SELECT 字段列表 FROM 表1 别名A JOIN 表1 别名B ON

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

    Mysql自连接查询「建议收藏」

    自连接查询 假想以下场景:某一电商网站想要对站内产品做层级分类,一个类别下面有若干子类,子类下面也会有别的子类。...我们可以在数据库中创建两个字段来存储id和类别名称,使用第三个字段存储类别的子类或者父类的id,最后通过自连接去查询想要的结果。...自连接查询其实等同于连接查询,需要两张表,只不过它的左表(父表)和右表(子表)都是自己。做自连接查询的时候,是自己和自己连接,分别给父表和子表取两个不同的别名,然后附上连接条件。...查询所有分类以及分类的父类:假想有左右两张表(都是tdb_cates),左表是子表,右表是父表;查询子表的id,子表的cate_name,父表的cate_name;连接条件是子表的parent_id等于父表的...查询所有分类以及分类的子类:还是假想有左右两张表(都是tdb_cates),左表是子表,右表是父表;查询子表的id,子表的cate_name,父表的cate_name;连接条件是子表的id等于父表的parent_id

    1.5K20

    Mysql中的关联查询(内连接,外连接,自连接)

    在使用数据库查询语句时,单表的查询有时候不能满足项目的业务需求,在项目开发过程中,有很多需求都是要涉及到多表的连接查询,总结一下mysql中的多表关联查询 一,内连接查询 是指所有查询出的结果都是能够在连接的表中有对应记录的...: 此时,就要使用内连接查询,关键字(inner join) 在这里说一下关联查询sql编写的思路,1,先确定所连接的表,2,再确定所要查询的字段,3,确定连接条件以及连接方式 select e.empName...,如果右表没有记录对应的话就显示null 查询结果: 关键字是left outer join,等效于left join,在关联查询中,做外连接查询就是左连接查询,两者是一个概念 三,右外连接是同理的...: 如果在oracle中,直接就使用full outer join关键字连接两表就行了 五,自连接查询 自连接查询就是当前表与自身的连接查询,关键点在于虚拟化出一张表给一个别名 例如:查询员工以及他的上司的名称...所以,自连接查询一般用作表中的某个字段的值是引用另一个字段的值,比如权限表中,父权限也属于权限。

    3.9K40

    mysql多表查询 浅谈mysql中等值连接与非等值连接、自连接与非自连接、内连接与外连接问题(一)

    AND 操作符 拓展2:区分重复的列名 多个表中有相同列时,必须在列名之前加上表名前缀。...说明 :对多表进行查询记录、更新记录、删除记录时,如果对操作列没有限定表的别名(或表 名),并且操作列在多个表中存在时,就会抛异常。...e, job_grades j WHERE e.salary BETWEEN j.lowest_sal AND j.highest_sal; 分类2:自连接 vs 非自连接 当table1和table2...#7.2 自连接 VS 非自连接 SELECT * FROM employees; #练习:查询员工姓名及其管理者的id和姓名[SQL] SELECT emp.employee_id,...vs 外连接 除了查询满足条件的记录以外,外连接还可以查询某一方不满足条件的记录。

    3.1K20

    Mysql连接查询时查询条件放在On之后和Where之后的区别

    一开始还比较费解,后面回过神来才发现,犯了一个低级的错误,就是在使用left join时过滤条件放到on后面还是where后面是有区别的,如果没有搞清楚他们的区别,连表汇总的结果就会变少或者变多。...num from classes a left join students b on a.id = b.class_id where b.gender = 'F' group by a.name  查询结果...as num from classes a left join students b on a.id = b.class_id and b.gender = 'F' group by a.name 查询结果...FROM LT LEFT JOIN RT ON P1(LT,RT)) WHERE P2(LT,RT) 其中P1是on过滤条件,缺失则认为是TRUE,P2是where过滤条件,缺失也认为是TRUE,该语句的执行逻辑和关键的执行流程可以描述为...on 后跟关联表(从表)的过滤条件,where 后跟主表或临时表的筛选条件(左连接为例,主表的数据都会查询到,所以临时表中必定包含主表所有的字段,需要给主表加什么筛选条件,直接给临时表加效果相同) 总结

    1.7K10

    mysql多表查询(一口气解决掉:自连接 左右连接 满连接等)

    多表查询,也称为关联查询,指两个或更多个表一起完成查询操作。 前提条件:这些一起查询的表之间是有关系的(一对一、一对多),它们之间一定是有关联字段,这个关联字段可能建立了外键,也可能没有建立外键。...它的作用就是可以把任意表进行连接,即使这两张表不相关  阿里开发规范: 【强制】对于数据库中表记录的查询和变更,只要涉及多个表,都需要在列名前加表的别名(或表名)进行限定。...说明:对多表进行查询记录、更新记录、删除记录时,如果对操作列没有限定表的别名(或表名),并且操作列在多个表中存在时,就会抛异常。...自连接  当table1和table2本质上是同一张表,只是用取别名的方式虚拟成两张表以代表不同的意义。然后两个表再进行内连接,外连接等查询。...`department  在正式开始讲连接表的种类时,我们首先需要知道 SQL 存在不同版本的标准规范,因为不同规范下的表连接操作是有区别的。

    77830

    算法工程师-SQL进阶:神奇的自连接与子查询

    自连接与子查询是SQL中非常重要的两项技术,自连接是针对相同的表的联结方法,是SQL语言面向集合编程思想的集中体现,而子查询有很多变式,关联子查询技术是在实际中进行行与行之间的比较时非常重要的方法,特别是与自连接相结合的自关联子查询...因此,子查询的本质就是一次性的视图。子查询可以无限嵌套,作为最内层查询会首先执行。 有一种比较特殊的子查询,它的返回结果是单一的值,即返回一个数(标量),叫做标量子查询。...一般来说,关联子查询和自连接是可以等价替换的,即能用自连接写的SQL,也能用关联子查询写出来。在后面的实战篇会有很多这样的例子。...解析:这段SQL同时使用了自连接和关联子查询,子查询用于筛选距离now_year最近的年份,并将其用于自连接的连接条件,非常巧妙。...使用关联子查询的SQL,往往也可以使用自连接的方式。 关联子查询的代码的可读性不好,而且性能也不好,特别是在 SELECT 子句里使用标量子查询时,性能可能会变差。

    3.5K10

    执行ALTER TABLE语句时如何避免长时间阻塞并发查询

    最近看到这样的案例: 1、应用需要为现有的表添加列 2、应用执行ALTER TABLE ADD COLUMN语句 3、其他每个查询都需要被阻塞几分钟甚至更长时间 为什么出现这种情况?如果避免?...首先看下执行ALTER TABLE ADD COLUMN时发生了什么?...这种事情发生在有其他查询在这个表上,然后在执行alter table,alter table需要等待之前的锁释放: (SESSION 1) =# BEGIN; BEGIN (SESSION 1) =...(SESSION 2) =# ALTER TABLE test ADD COLUMN whatever2 int4; 会话2执行alter 语句时由于需要等待会话1释放锁被阻塞,但是他已经获取这个表上的...那么,是否存在这样的语句,执行添加列时不申请长时间锁表的锁?pg_reorg/pg_repack。

    2.6K10

    MySQL【三】---数据库查询详细教程{分页、连接查询、自关联、子查询、数据库设计规范}

    select * from student order by age asc limit 5,2; 2.连接查询【多表使用】 多个表里合并数据时使用,目前创建了两个表【见相关文章2】 链接查询:inner...】 3.自关联 应用: 表示通过一张表实现逻辑关联查询,类似于省-市-县  自关联自己关联自己: 数据下载链接: https://download.csdn.net/download/sinat...4.1标量子查询; 查询最高的男生信息 select * from students where height=(select max(height) from students); 子查询即先执行子语句得到结论...,再把这个结论当作条件再执行主语句; 对于:上面河北省自关联可以采用子查询解决: select* from areas where pid = (select aid from areas where...多值属性(multivalued attributes)用两条线与实体连接,eg:hobbies属性(一个人可能有多个hobby,如reading,movies…)。

    1.7K20

    【MySQL】多表查询全解-【多表关系内外自连接子查询多表查询案例链接】(可cv代码&案例演示)

    —连接查询连接 ※多表查询分类概述 我们简单了解有哪两种查询方式,具体看下文 1.连接查询-内连接查询(语法&示意图&案例演示) 注意: inner可省略 我们编写内连接sql语句时: 1.先列出表结构...连接条件…; --内连接演示-- --1.查询每一个员工的姓名,及关联的部门的名称(隐式内连接实现) --表结构:emp,dept --连接条件:emp.dept_id=dept.id select...2.连接查询-外连接查询(语法&示意图&案例演示) 如下图中示意图所示: 外连接可以查询内连接查不到的数据 , (左外连接)即图中蓝色部分,完全左表信息 我们再举个例子来理解: 我们现在有一个员工表...条件…; --1.查询dept表的所有数据,和对应的员工信息(左外连接) --表结构:emp,dept --连接条件:emp.dept_id =dept.id select e.*, d.name from...-自连接查询(语法&示意图&案例演示) 注意:自连接查询,可以是内连接查询,也可以是外连接查询。

    1.7K10

    Mysql使用left join连表查询时,因连接条件未加索引导致查询很慢

    背景 最近一个后台功能列表,业务人员反馈查询和导出速度非常慢。 通过定位发现列表查询和数据导出都是使用的同样的一个连表查询SQL。...这个功能刚上线不久,起初查询和导出速度都是蛮快的,把这个SQL放到测试环境也是挺快的。...解决 通过对table c中的连接字段content_id和user_no分别加上了索引, 加上索引后的执行计划如下  总结 需要注意:参与join的表,需要在连接条件上建索引。...假定要使用以下连接类型执行三个表t1,t2和t3之间的连接: Table Join Type t1 range t2 ref t3 ALL 如果使用一个简单的NLJ算法...由于索引的效率要比逐条循环效率高,所以当使用索引联表时,能大大加快查询速度,但是索引也不是万能的,如果你需要取索引以外的字段,那么依旧需要回到表中查出相应的数据。

    2.5K10
    领券