• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL多表连接查询详解

    多表连接查询

    表与表之间的连接分为内连接和外连接

    内连接

    首先准备两张表

    学生student表

    分数score表

    内连接:在每个表中找出符合条件的共有记录
    查询student表中的学生姓名和分数

    第一种写法:只使用where

    select a.s_name, b.s_score from student a,score b where a.s_id = b.s_id;

    第二种写法:join … on…

    select a.s_name, b.s_score from student a join score b on a.s_id = b.s_id
    

    第三种写法:inner join … on…

    select a.s_name, b.s_score from student a inner join score b on a.s_id = b.s_id
    

    左连接

    左连接:根据左表的记录,在被连接的右表中找出符合条件的记录与之匹配,如果找不到与左表匹配的,用null表示

    第一种写法:left join … on …

    select a.s_name,b.s_score from student a left join score b on a.s_id = b.s_id
    

    第二种写法:left outer join … on …

    select a.s_name,b.s_score from student a left outer join score b on a.s_id = b.s_id
    

    右连接

    **右连接:**根据右表的记录,在被连接的左表中找出符合条件的记录与之匹配,如果找不到匹配的,用null表示

    第一种写法:right join … on …

    select a.s_name,b.s_score from student a right join score b on a.s_id = b.s_id;
    

    第二种写法:right outer join … on …

    select a.s_name,b.s_score from student a right outer join score b on a.s_id = b.s_id;
    

    子查询

    子查询:是多表连接查询的一种实现方式,在一个select语句的from子句或where子句中嵌套了另一个select语句,外层的select查询语句成为主查询,换句话将就是WHERE或FORM中的查询语句称为子查询

    WHERE子句中的子查询:子查询返回的值作为主查询的查询条件

    FROM子句中的子查询:子查询返回的是一张虚拟的表,主查询从该查询从临时表查询出满足的条件

    总结

    本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

    您可能感兴趣的文章:
    • MySQL的时间差函数TIMESTAMPDIFF、DATEDIFF的用法
    • MySQL的时间差函数(TIMESTAMPDIFF、DATEDIFF)、日期转换计算函数(date_add、day、date_format、str_to_date)
    • 实现MySQL + PostgreSQL批量插入更新insertOrUpdate
    • MYSQL row_number()与over()函数用法详解
    • MySQL隐式类型转换导致索引失效的解决
    • 浅谈MySQL数据查询太多会OOM吗
    • Django搭建MySQL主从实现读写分离
    • mysql中TIMESTAMPDIFF案例详解
    上一篇:sqlmap注入图文详解
    下一篇:浅谈MySQL数据查询太多会OOM吗
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL多表连接查询详解 MySQL,多表,连接,查询,详解,