作品:
AND UPPER(a.name) = b.lname(+)
不工作
AND UPPER(a.name) = UPPER(b.lname) (+)
迁移到 ANSI 连接是一种选择,但却是一项艰苦的选择。这段代码应该在很多地方更改,并且有很多连接。我想让这个语法正确并继续前进。
是否可以?
作品:
AND UPPER(a.name) = b.lname(+)
不工作
AND UPPER(a.name) = UPPER(b.lname) (+)
迁移到 ANSI 连接是一种选择,但却是一项艰苦的选择。这段代码应该在很多地方更改,并且有很多连接。我想让这个语法正确并继续前进。
是否可以?
除了令人讨厌之外,将 UPPER() 与旧的 skool OUTER JOIN 语法结合起来本身就很简单:我们只需要以正确的顺序获取括号:
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>
代码的第二个版本很可能永远不会工作。如果它以前没有使用过,那么它不起作用的可能性就更大了。(有关如何使用过时的表示法,请参阅已接受的答案。我仍然认为以下建议的其余部分是有效的 - 但请仔细注意限定符“当您需要修改 SQL 时”;如果您不需要更改 SQL由于某些其他原因,没有必要删除旧式表示法。)
当您需要进行不区分大小写的比较时,咬紧牙关处理 ANSI 连接。或者,如果 Oracle 中存在这样的选项,则调查基于区域设置的替代方案(使用不区分大小写的比较)。
但是,从根本上说,您应该将旧的“(+)”外部连接符号放入垃圾箱。当您必须修改 SQL 语句时,请删除旧的(过时的)表示法并改用 ANSI 连接表示法。
有评论询问“如何将其转换为 ANSI”?
您重写了 FROM 子句以及 WHERE 子句 - 通常将连接条件从 WHERE 子句移至 FROM 子句中的 ON 条件。
SELECT a.*, b.*
FROM a LEFT OUTER JOIN b ON UPPER(a.name) = UPPER(b.lname)
另一条评论询问“如何将连接扩展到三个表”?
SELECT a.*, b.*
FROM a
LEFT OUTER JOIN b ON UPPER(a.name) = UPPER(b.lname)
LEFT OUTER JOIN c ON on a.first = c.first
AND UPPER(a.name) = UPPER(b.lname (+))
作品。我测试了它。它工作正常。