zoukankan      html  css  js  c++  java
  • MySQL联合查询语法内联、左联、右联、全联

    MySQL联合查询效率较高,以下例子来说明联合查询(内联、左联、右联、全联)的好处:
    T1表结构(用户名,密码)   
    userid(int)   usernamevarchar(20)   passwordvarchar(20)   
    1   jack  jackpwd   
    2   owen  owenpwd    T2表结构(用户名,密码)   
    userid(int)   jifenvarchar(20)   dengjivarchar(20)        1   20   3        3   50   6   
    第一:内联(inner join)
    如果想把用户信息、积分、等级都列出来,那么一般会这样写:
    select * from T1, T3 where T1.userid = T3.userid
    (其实这样的结果等同于select * from T1 inner join T3 on T1.userid=T3.userid )。
    把两个表中都存在userid的行拼成一行(即内联),但后者的效率会比前者高很多,建议用后者(内联)的写法。
    SQL语句:
    select * from T1 inner join T2 on T1.userid = T2.userid
    运行结果   
    T1.userid   username   password   T2.userid   jifen   dengji   
    1   jack   jackpwd   1   20   3    第二:左联(left outer join)
    显示左表T1中的所有行,并把右表T2中符合条件加到左表T1中;
    右表T2中不符合条件,就不用加入结果表中,并且NULL表示。
    SQL语句:
    select * from T1 left outer join T2 on T1.userid = T2.userid
    运行结果   
    T1.userid   username   password   T2.userid   jifen   dengji   
    1   jack   jackpwd   1   20   3   
    2   owen   owenpwd   NULL   NULL   NULL  

    第三:右联(right outer join)。
    显示右表T2中的所有行,并把左表T1中符合条件加到右表T2中;
    左表T1中不符合条件,就不用加入结果表中,并且NULL表示。
    SQL语句:
    select * from T1 right outer join T2 on T1.userid = T2.userid
    运行结果   
    T1.userid   username   password   T2.userid   jifen   dengji   
    1   jack   jackpwd   1   20   3   
    NULL   NULL   NULL   3   50   6  

    第四:全联(full outer join)
    显示左表T1、右表T2两边中的所有行,即把左联结果表 + 右联结果表组合在一起,然后过滤掉重复的。
    SQL语句:
    select * from T1 full outer join T2 on T1.userid = T2.userid
    运行结果   
    T1.userid   username   password   T2.userid   jifen   dengji   
    1   jack   jackpwd   1   20   3   
    2   owen   owenpwd   NULL   NULL   NULL   
    NULL   NULL   NULL   3   50   6  
    总结,关于联合查询,效率的确比较高,4种联合方式如果可以灵活使用,基本上复杂的语句结构也会简单起来。

     

     更多(三张表以上)表联合查询示例(可按照示例灵活运用)

    新建三表:
    表A:  student 截图如下:
    SQL多表连接查询(详细实例)_新客网
    表B:  course 截图如下:
    SQL多表连接查询(详细实例)_新客网
    表C:  student_course 截图如下:
    SQL多表连接查询(详细实例)_新客网
    一个学生可以选择多门课程,一门课程可以被多个学生选择,因此学生表student和课程表course之间是多对多的关系。
    当两表为多对多关系的时候,我们需要建立一个中间表student_course,中间表至少要有两表的主键,当然还可以有别的内容。
    SQL语句:select s.Name,C.Cname from student_course as sc left join student as s on s.Sno=sc.Sno left join course as c on c.Cno=sc.Cno
    执行结果:
    SQL多表连接查询(详细实例)_新客网
    此条SQL执行的结果是学生选课的情况。

    原文转自:http://blog.csdn.net/yl_wh/article/details/8649909

    部分内容来自:http://www.dedecms.com/knowledge/data-base/sql-server/2012/0709/2872.html

  • 相关阅读:
    怎样判断数组类型
    VS2017不能生成Database Unit Test项目
    Windows Server 远程桌面报错:No Remote Desktop License Servers Available
    TFS2018 获取所有Build变量及变量值
    C# 读写bat文件
    【PowerShell 学习系列】-- 删除Win10自带应用
    Win10
    【TFS】TFS2015链接TFS出现TF31002/TF400324问题解决方案
    【SQL Server 学习系列】-- 获取字符串中出现某字符的次数及字符某次出现的下标
    【.Net 学习系列】-- 利用Aspose转换Excel为PDF文件
  • 原文地址:https://www.cnblogs.com/harxingxing/p/4647900.html
Copyright © 2011-2022 走看看