Re: [SQL ] JOIN的CASE WHEN 问题

楼主: cutekid (可爱小孩子)   2014-10-14 08:46:16
SELECT A.*,ISNULL(B1.EMPCNAME,B2.EMPCNAME) AS EMPCNAME
FROM A
LEFT JOIN B AS B1 ON A.CUSTNO = B1.CUSTNO
LEFT JOIN B AS B2 ON A.BLOCNO = B2.BLOCNO
WHERE (A.CUSTNO IS NOT NULL AND A.CUSTNO = B2.CUSTNO) OR
(A.CUSTNO IS NULL) OR (A.BLOCNO IS NULL)
※ 引述《stickzor (Sam鸡)》之铭言:
: (针对 SQL 语言的问题,用这个标题。请用 Ctrl+Y 砍掉这行)
: 数据库名称:MSSQL
: 数据库版本:10.50.4000.0
: 内容/问题描述:
: 各位前辈好,
: 问题如这张图
: http://imgur.com/MOFfVWB
: 想请问下我想把第二张的left join 给第一张,
: 第三张是想要的结果。
: 原本有找过类似的文章
: https://www.ptt.cc/bbs/Database/M.1402392236.A.E94.html
: 但是有一个条件不太一样就是我要比对的字段可能是null,
: 如果是null则换成第二栏来on,
: (ex 如果A.custno 是 null 则 b2.blocno =A.blocno 不然的话就是
: A.custno = b1.custno )
: 我最后写出
: SELECT A.*,(ISNULL(b1.empcname,b2.empcname)) as empcname1
: FROM A
: left join B as b1 on A.custno = b1.custno
: left join B as b2 on b2.blocno =A.blocno
: 但是有问题就是会有重复值。
: 所以想问一下,
: 能否有更好的写法 谢谢。
作者: stickzor (Sam鸡)   2014-10-14 10:50:00
非常感谢你谢谢

Links booklink

Contact Us: admin [ a t ] ucptt.com