• 明确一个古老的问题left join,right join,inner join,full join,cross join


    left join   :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。
    right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。
    inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行。
    full join:外连接,返回两个表中的行:left join + right join
    cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数。
    补充说明:如果表一中的某行对应表二中的两行记录,那么结果集中会有两条记录对应,right join也同样道理。
    ----------------------------------------------------------------------------------------------------

    例子

    declare @a table(a int,b int)
    declare @b table(a int,b int)

    insert @a values(1,1)
    insert @a values(2,2)
    insert @b values(1,1)
    insert @b values(3,3)
    select * from @a
    select * from @b
    --左:
    select * from @a Aa left join @b Bb on Aa.a=Bb.a
    --右:
    select * from @a Aa right join @b Bb on Aa.a=Bb.a
    --内
    select * from @a Aa inner join @b Bb on Aa.a=Bb.a
    --外:
    select * from @a Aa full join @b Bb on Aa.a=Bb.a
    --交叉连接
    select * from @a  cross join @b



    分享到:
  • 相关阅读:
    Android Wifi BT的工作流程和porting(精)
    ioctl命令详解
    android 编译库过程
    git恢复repo start 后丢失的修改记录
    Android Bluetooth 分析(精)
    SDIO总线 驱动
    提取高通最新代码patch
    linux设备驱动——andriod平台wlan驱动
    推送现有git到远程服务器并创建新分支
    c++继承经典例子
  • 原文地址:https://www.cnblogs.com/qqflying/p/1245152.html
Copyright © 2020-2023  润新知