zoukankan      html  css  js  c++  java
  • sqlserver之on与where条件

    挺特别的,on后边的条件以前我只写一个关联的id 之类的,后来发现还可以加条件,比如左表 用户表,右表用户订单表,订单有很多,可以加上时间范围列出某天订单.

    很多人会说加where 就可以了,如果还要列出当日没下单的用户呢,where明显就不够了,其实在on后边再加个时间条件就行了,  left join 大家都知道,左侧表数据是不管有没有关联上是会保留的

    但加了where 条件除外.

    产品表

    ProNo ProName Price Stocks
    00001 电视 3000.00 800
    00002 空调 2000.00 500
    00003 床 1000.00 300
    00004 餐桌 1500.00 200
    00005 音响 5000.00 600
    00006 沙发 6000.00 100
    00007 窗帘 500.00 100

    产品入库表

    InputDate    ProNo    Quantity
    2006-01-01 00:00:00.000    00001    10
    2006-01-01 00:00:00.000    00002    5
    2006-01-02 00:00:00.000    00001    5
    2006-01-02 00:00:00.000    00003    10
    2006-01-03 00:00:00.000    00001    10
    2006-02-01 00:00:00.000    00003    20
    2006-02-02 00:00:00.000    00001    10
    2006-02-03 00:00:00.000    00003    20
    2006-02-03 00:00:00.000    00004    30
    2020-12-24 16:48:02.043    00001    10
    2020-12-24 16:48:04.887    00001    10
    2020-12-24 16:48:12.933    00002    10
    2020-12-24 16:48:14.527    00002    10
    2020-12-24 16:48:20.747    00003    10
    2020-12-24 16:48:22.287    00003    10
    2020-12-24 16:48:29.710    00004    10
    2020-12-24 16:48:31.043    00004    10
    2020-12-24 16:48:48.683    00004    10
    2020-12-24 16:48:57.200    00005    10
    2020-12-24 16:48:58.353    00005    10
    2020-12-24 16:48:59.060    00005    10
    2020-12-24 16:48:59.863    00005    10
    2020-12-24 16:49:06.040    00006    10
    2020-12-24 16:49:06.500    00006    10
    select  *  from Product left join ProIn on Product.ProNo=ProIn.ProNo  and ProIn.InputDate>'20201223'

       select  *  from Product left join ProIn on Product.ProNo=ProIn.ProNo  where ProIn.InputDate>'20201223'

     null没了 

    看一下 sql  实行顺序

    查一下MSDN就清楚了整个SQL的执行顺序.
    
    http://msdn.microsoft.com/en-us/library/ms189499(v=SQL.100).aspx
    
    Processing Order of the SELECT statement
    The following steps show the processing order for a SELECT statement.
    
    1.FROM
    
    2.ON
    
    3.JOIN
    
    4.WHERE
    
    5.GROUP BY
    
    6.WITH CUBE or WITH ROLLUP
    
    7.HAVING
    
    8.SELECT
    
    9.DISTINCT
    
    10.ORDER BY
    
    11.TOP
    
     
    
    也就是说, 先进行on的过滤, 而后才进行join, 这样就避免了两个大表产生全部数据的笛卡尔积的庞大数据. 
  • 相关阅读:
    可视化工具Navicat 视图 事物 存储过程
    mysql用户管理 + pymysql的使用
    0914 表与表之间的关系补充一对一关系 记录操作 关键字 多对多 子查询
    0913数据库约束之主键 外键 非空 默认值约束 唯一约束 级联操作 表与表之间的联系
    数据库的数据类型
    面向对象之继承
    面向对象
    re模块
    加密常用模块
    日志模块
  • 原文地址:https://www.cnblogs.com/zuochanzi/p/14185285.html
Copyright © 2011-2022 走看看