数据表:

关联子查询 mysql 优化 关联sql查询写法举例_关联子查询 mysql 优化

关联子查询 mysql 优化 关联sql查询写法举例_后端_02

关联子查询 mysql 优化 关联sql查询写法举例_android_03

关联子查询 mysql 优化 关联sql查询写法举例_前端_04

关联查询主要分为:(inner join)交叉关联、(left join)左关联、(right join)右关联

(inner join)交叉关联:

  1. 定义:(inner join)交叉关联只返回两个表联结相等的字段的行
  2. 语法:select * from 表1

inner join 表2

on 表1.字段号=表2.字段号

比如我要查学生表和成绩表的交叉关联,那首先要找到它们联结相等的字段

关联子查询 mysql 优化 关联sql查询写法举例_后端_05

它们唯一相同的字段就是学号这个字段

那么按照上面的语法写就是:

关联子查询 mysql 优化 关联sql查询写法举例_关联子查询 mysql 优化_06

关联子查询 mysql 优化 关联sql查询写法举例_字段_07

  1. 注意看,输出表是只有5个学生的的信息的,但是我们的学生表是一共拥有10个学生的,它的定义是只返回两个表联结相等的字段的行,

关联子查询 mysql 优化 关联sql查询写法举例_字段_08

成绩表里只有5个学生的学号,相对等学生表联结的只能是5个学生的信息

关联子查询 mysql 优化 关联sql查询写法举例_前端_09

(left join)左关联:

  1. 定义:(left join)左关联返回包括左表的所有记录和右表中联结字段相等的记录
  2. 语法:select * from 表1

left join 表2

on 表1.字段号=表2.字段号

关联子查询 mysql 优化 关联sql查询写法举例_字段_10

那要查学生表和成绩表的左关联先参照语法打一遍,效果如下:

关联子查询 mysql 优化 关联sql查询写法举例_关联子查询 mysql 优化_11

关联子查询 mysql 优化 关联sql查询写法举例_android_12

左关联就是以左表为主体,右表有数据就显示,没有数据就显示null

(right join)右关联:

  1. 定义:(right join)右关联返回包括右表的所有记录和左表中联结字段相等的记录
  2. 语法:select * from 表1

right join 表2

on 表1.字段号=表2.字段号

右关联就刚好和左关联相反

关联子查询 mysql 优化 关联sql查询写法举例_关联子查询 mysql 优化_13

关联子查询 mysql 优化 关联sql查询写法举例_字段_14

关联子查询 mysql 优化 关联sql查询写法举例_前端_15

先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。