美文网首页
MySQL基础-连接查询

MySQL基础-连接查询

作者: 小飞船1号 | 来源:发表于2020-12-11 10:43 被阅读0次

一、等值连接 .....=......

select * from 表1 as b1,表2 as b2 where b1.字段=b2.字段
再有其他条件,直接加在后边即可
select * from stu,course,score 
where stu.stuid=score.stuid and  course.cid=score.cid 
  • 必须要出现后边的等值条件,按照=的两边,取交集
  • 不会出现新表,只是一个显示结果
  • 先连接成一个笛卡尔积(生成记录总数=表1的总数*表2的总数),在根据条件筛选
  • 会产生临时表,占内存

二、内连接 inner join.....on.......

select * from 表1 
inner join 表2   on 表1.字段=表2.字段
where 条件
order by .....
limit ....

select * from stu
inner join  score  on where stu.stuid=score.stuid
inner join  course on course.cid=score.cid
where stu.name='王昭君'
#先两个表连接,在和第三个表连接
#*要写成列名时,列名要加前缀表明是哪个表的,有重复的
#起别名,只能用别名
  • 先根据条件筛选,在连接两个表
  • 不会产生临时表,不占内存,性能高一些
img_innerjoin.gif

三、左连接 left join.....on.....

select * from 表1 
left join 表2   on 表1.字段=表2.字段

select * from stu
left join  score  on where stu.stuid=score.stuid
#join前边生成的结果作为左表
left join  course on course.cid=score.cid
#查询所有学生的成绩,包括没有成绩的学生,需要显示课程名
  • join前面生成的结果作为左边,join后面的是右表,把左表的数据全部显示
  • 取左表所有结果,右表有符合的连接到一起成一条数据,没有符合的右表部分字段就都填上null成一条数据
  • 和内连接的区别就是,内连接没找到符合的不会显示null,该条不会存在表中,所以只要有右表不符合的情况,左表结果不会全部显示
img_leftjoin.gif

四、右连接 right join....on.....

select * from 表1 
right join 表2   on 表1.字段=表2.字段

select * from score 
right join  course on where course.cid=score.cid 
left join  stu on  stu.stuid=score.stuid
#查询所有课程的成绩,包括没有成绩的课程,需要显示学生信息
  • join前面生成的结果作为左边,join后面的是右表,把右表的数据全部显示
  • 取右表所有结果,左表有符合的连接到一起成一条数据,没有符合的左表部分字段就都填上null成一条数据
img_rightjoin.gif

使用左右连接(题目中包含所有,没有字眼需要用到左右连接)

  • 只要明白那个是左表、右表;
  • 那个需要所有结果;
  • 那个需要null值;

五、自关联

  • 一个表关联多次


select * from areas as sheng,areas  as shi
where sheng.aid=shi.pid

select * from areas as sheng,areas  as shi,areas  as qu
where sheng.aid=shi.pid and shi.aid=qu.pid
  • 数据之间有上下级关系
  • 在一个表中存储所有数据
  • 从一个表中查询多次,必须起别名

相关文章

  • Mysql

    mysql 基础语法 // 数据库 表 insert select update delete 连接查询 内连接:...

  • MySQL基础-连接查询

    一、等值连接 .....=...... 必须要出现后边的等值条件,按照=的两边,取交集 不会出现新表,只是一个显示...

  • 大厂面试超高频MySQL题目(含答案):基础+索引+事务+锁

    MySQL基础篇 说一下 MySQL 执行一条查询语句的内部执行过程? 客户端先通过连接器连接到 MySQL 服务...

  • MySQL 基本内容

    MySQL的基础 MySQL 数据类型 SQL mode 多表查询代价高一张表——>两个表——>需要连接连接 需要...

  • mysql连接查询,自关联,子查询

    mysql支持三种类型的连接查询,分别为:内连接查询,左连接查询,右连接查询 内连接查询: 左连接查询: 右连接查...

  • python下MySQL的使用

    mysql连接 全部查询 单个查询 更新数据

  • MySQL基础架构-架构详解

    mysql基础架构图 架构详解 连接器部分 整体功能 建立连接 维持管理连接 校验用户名密码,查询权限 最佳实践 ...

  • 服务之路(一)

    连接mysql 使用koa框架,连接mysql,查询数据并通过接口返回

  • mysql基础

    mysql基础知识 1.创建数据库 2.连接查询 1.内连接(INNER JOIN) 2.左外连接(LEFT OU...

  • mysql 查询

    mysql的查询、子查询及连接查询 一、mysql查询的五种子句 where(条件查询)、having(筛选)、g...

网友评论

      本文标题:MySQL基础-连接查询

      本文链接:https://www.haomeiwen.com/subject/xxjrgktx.html