CCCCCCCYYY_ 2019-07-28 11:19 采纳率: 50%
浏览 679
已采纳

sql语句中Left join的on和where

问题是并了几张表,其中有left join 或者inner join的,比如下面这样

SELECT * from 
(SELECT a.inserttime, a.Num 
FROM test.contract a 
LEFT JOIN test.customer b ON a.Num = b.Num2) tmp 
LEFT JOIN test.customer4 d ON tmp.num = d.num4 ; 

然后现在想取出的是a.inserttime > '2019-5-5'的数据,该用where还是on呢?
该写在哪里?是要在最外面再包一层select用where a.inserttime > '2019-5-5'吗?

  • 写回答

6条回答 默认 最新

  • Burcy Wen 2019-07-28 12:09
    关注

    以mysql为例,
    查询条件insertime,直接写在括号里,由于有外联,where条件写在括号内的外联后,

    SELECT * from 
    (SELECT a.inserttime, a.Num 
    FROM contract a 
    LEFT JOIN customer b ON a.Num = b.Num2
    WHERE a.inserttime > '2019-07-28') tmp 
    LEFT JOIN customer4 d ON tmp.num = d.num4 ;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 matlab有关常微分方程的问题求解决
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?
  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable