zoukankan      html  css  js  c++  java
  • SQL联合查询

    联合查询效率较高.以下例子来说明联合查询的好处

    t1表结构(用户名,密码)    userid int         username   varchar(20)     password       varchar(20)

                                           1                    jack                           jackpwd

                                           2                    owen                        owenpwd

    t3表结构(用户积分,等级)    userid int         jf   int                   dj           int

                                            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的行拼成一行.这是内联.但后者的效率会比前者高很多.建议用后者的写法.

    运行结果:userid    username password     userid   jf    dj

                 1             jack        jacjpwd      1          20   3

    第二:左联(left outer join)显示左表中的所有行

    select * from t1 left outer join t3 on t1.userid=t3.userid

    运行结果:userid    username password     userid   jf     dj

          1        jack          jackpwd       1         20   3

                     2       owen         owenpwd     NULL NULL   NULL

    第三:右联(right outer join)显示右表中的所有行

    select * from t1 right outer join t3 on t1.userid=t3.userid

    运行结果:userid    username password     userid   jf     dj

          1        jack          jackpwd       1         20   3

                    Null      Null           Null             3        50     6

    第四:全联(full outer join)显示两边表中所有行

    select * from t1 full outer join t3 on t1.userid=t3.userid

    运行结果:userid    username password     userid   jf     dj

          1        jack          jackpwd       1         20   3

                     2       owen         owenpwd     NULL NULL   NULL

                     Null    Null           Null              3        50     6

    总结,关于联合查询,本人已测试过.效率的确比较高,4种联合方式如果可以灵活使用,基本上复杂的语句结构也会简单起来.这4种方式是:

    Inner join          left outer join           right outer join        full outer join

    内连接: SELECT A.* FROM A INNER JOIN B ON A.ID=B.ID

    左外连接: SELECT A.* FROM A LEFT JOIN B ON A.ID = B.ID

    右外连接: SELECT A.* FROM A RIGHT JOIN B ON A.ID = B.ID

    全外连接: SELECT A.*, B.* FROM A FULL OUTER JOIN B ON A.ID = B.ID

    JOIN 分为内连接,外连接(左外连接,右外连接,全外连接)
    内连接: 相当与自然连接。 结果把a和b中的重复结果去掉。
    左外连接:左表(a)的数据全部保存,而右表数据去掉与a表的重复记录。
    右外连接:右表(b)的数据全部保存,而左表数据去掉与b表的重复记录。
    全外连接相当与笛卡尔积。保存a和b的全部记录。

  • 相关阅读:
    linux安装navicat全程记录
    MySQL5.7.20报错Access denied for user 'root'@'localhost' (using password: NO)
    java中的异步处理和Feature接口(一)
    @Autowired注解与@Resource注解的区别与用法
    超详细MySQL安装及基本使用教程
    linux下mysql开启远程访问权限及防火墙开放3306端口
    mysql之my.cnf详解
    centos7 mysql 启动mysqld.service
    linux系统安装mysql数据库
    ExecutorService 的理解与使用
  • 原文地址:https://www.cnblogs.com/muran/p/2395966.html
Copyright © 2011-2022 走看看