zoukankan      html  css  js  c++  java
  • mysql 表关联时执行顺序

    left join  左连接

     1 with temp1 as (
     2 select 1 as id ,12 as num union 
     3 select 2 as id ,13 as num union 
     4 select 3 as id ,12 as num union 
     5 select 4 as id ,14 as num union 
     6 select 5 as id ,12 as num union 
     7 select 6 as id ,16 as num  
     8 ), temp2 as (
     9 select 1 as id ,'a' as var union 
    10 select 2 as id ,'b' as var union 
    11 select 3 as id ,'c' as var union 
    12 select 4 as id ,'a' as var union 
    13 select 5 as id ,'b' as var union 
    14 select 6 as id ,'f' as var  
    15 )
    16 select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id
    View Code

    left join  左连接 (on 中加条件)

    说明:先关联, 再过滤 ;

     1 with temp1 as (
     2 select 1 as id ,12 as num union 
     3 select 2 as id ,13 as num union 
     4 select 3 as id ,12 as num union 
     5 select 4 as id ,14 as num union 
     6 select 5 as id ,12 as num union 
     7 select 6 as id ,16 as num  
     8 ), temp2 as (
     9 select 1 as id ,'a' as var union 
    10 select 2 as id ,'b' as var union 
    11 select 3 as id ,'c' as var union 
    12 select 4 as id ,'a' as var union 
    13 select 5 as id ,'b' as var union 
    14 select 6 as id ,'f' as var  
    15 )
    16 -- select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id
    17 select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id and t1.num=12 
    18 -- select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id where t1.num=12
    View Code

    left join  左连接  (末尾 where 条件)

    说明:最后过滤

     1 with temp1 as (
     2 select 1 as id ,12 as num union 
     3 select 2 as id ,13 as num union 
     4 select 3 as id ,12 as num union 
     5 select 4 as id ,14 as num union 
     6 select 5 as id ,12 as num union 
     7 select 6 as id ,16 as num  
     8 ), temp2 as (
     9 select 1 as id ,'a' as var union 
    10 select 2 as id ,'b' as var union 
    11 select 3 as id ,'c' as var union 
    12 select 4 as id ,'a' as var union 
    13 select 5 as id ,'b' as var union 
    14 select 6 as id ,'f' as var  
    15 )
    16 -- select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id
    17 -- select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id and t1.num=12 
    18 select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id where t1.num=12
    View Code

    left join  左连接  ( on 中加条件 & 末尾 where 条件)

     1 with temp1 as (
     2 select 1 as id ,12 as num union 
     3 select 2 as id ,13 as num union 
     4 select 3 as id ,12 as num union 
     5 select 4 as id ,14 as num union 
     6 select 5 as id ,12 as num union 
     7 select 6 as id ,16 as num  
     8 ), temp2 as (
     9 select 1 as id ,'a' as var union 
    10 select 2 as id ,'b' as var union 
    11 select 3 as id ,'c' as var union 
    12 select 4 as id ,'a' as var union 
    13 select 5 as id ,'b' as var union 
    14 select 6 as id ,'f' as var  
    15 )
    16 select  * from temp1 t1 left join temp2 t2 on t1.id =t2.id and t1.num=12  where  t1.num=12
    View Code

  • 相关阅读:
    Django框架第九篇--Django和Ajax、序列化组件(serializers)、自定义分页器、模型表choice参数
    Django框架之第五篇(模板层) --变量、过滤器(|)、标签(% %)、自定义标签、过滤器、inclusion_tag,模板的继承、模板的注入、静态文件
    Django框架学习易错和易忘点
    守护线程
    Thread其他属性和方法
    进程与线程的区别
    开启线程
    关闭屏幕输出分屏显示
    生产者消费者模型
    队列
  • 原文地址:https://www.cnblogs.com/linbo3168/p/13359651.html
Copyright © 2011-2022 走看看