作品:
AND UPPER(a.name) = b.lname(+)不工作
AND UPPER(a.name) = UPPER(b.lname) (+)迁移到ANSI joins是一个选择,但这是一个艰苦的选择。这段代码应该在很多地方修改,并且有很多连接。我想让这个语法正确,这样我就可以上路了。
有可能吗?
发布于 2010-07-13 08:58:14
除了令人讨厌之外,使用旧的skool外部连接语法合并is ()本身就很简单:我们只需要以正确的顺序获得括号:
SQL> select t23.name
2 , d.university
3 from t23
4 , t_doctors d
5 where upper(t23.name) = upper(d.name(+))
6 order by t23.id
7 /
NAME UNIVERSITY
------------ --------------------
SAM-I-AM
MR KNOX
FOX IN SOCKS
CAT
LORAX
BILLY
MAISIE
DR SINATRA Whoville U
DR FONZ U of Grin-itch
PINNER BLINN
10 rows selected.
SQL> 以下是如何使用多个表部署较新的语法:
SQL> select t23.name
2 , d.university
3 , k.school
4 from t23
5 left outer join t_doctors d
6 on upper(t23.name) = upper(d.name)
7 left outer join t_kids k
8 on upper(t23.name) = upper(k.name)
9 order by t23.id
10 /
NAME UNIVERSITY SCHOOL
------------ -------------------- --------------------
SAM-I-AM Mulberry St Junior
MR KNOX
FOX IN SOCKS
CAT
LORAX
BILLY Roover River High
MAISIE Roover River High
DR SINATRA Whoville U
DR FONZ U of Grin-itch
PINNER BLINN
10 rows selected.
SQL>发布于 2013-06-07 05:56:15
AND UPPER(a.name) = UPPER(b.lname (+)) 很管用。我测试过了。它工作得很好。
https://stackoverflow.com/questions/3233220
复制相似问题