作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们从第三方产品继承了一组表格。其中一个表有 2 个外键约束,它们链接到父表上的同一列。我简化了表格来证明这一点:
CREATE TABLE profile_defn
(
profile_id NUMBER(10,0),
profile_name VARCHAR2(50),
CONSTRAINT pk1 PRIMARY KEY (profile_id)
);
CREATE TABLE letter_defn
(
letter_defn_id NUMBER(10,0),
letter_name VARCHAR2(50 BYTE),
orig_print_id NUMBER(10,0),
new_print_id NUMBER(10,0),
CONSTRAINT fk1 FOREIGN KEY (orig_print_id) REFERENCES profile_defn (profile_id) ENABLE,
CONSTRAINT fk2 FOREIGN KEY (new_print_id) REFERENCES profile_defn (profile_id) ENABLE
);
INSERT INTO profile_defn
VALUES
(
1,
'profile1'
);
INSERT INTO profile_defn
VALUES
(
2,
'profile2'
);
INSERT INTO profile_defn
VALUES
(
3,
'profile3'
);
INSERT INTO letter_defn
VALUES
(
1,
'letter1',
1,
2
);
INSERT INTO letter_defn
VALUES
(
1,
'letter2',
2,
3
);
因此,当连接 2 个表时,有一个 OR 条件,因为它需要识别任一列上的匹配记录:
SELECT * FROM letter_defn ld
JOIN profile_defn p
ON ld.orig_print_id = p.profile_id OR ld.new_print_id = p.profile_id;
在 JOIN 中使用 OR 是否有任何后果,或者是否有“更好”的方法?
谢谢。
最佳答案
另一种方法是使用 UNION
或 UNION ALL
,它们可能有更好的执行计划:
SELECT * FROM letter_defn ld
JOIN profile_defn p ON ld.orig_print_id = p.profile_id
UNION
SELECT * FROM letter_defn ld
JOIN profile_defn p ON ld.new_print_id = p.profile_id;
后果
是或
通常较慢,因为编译器无法再执行索引查找。除此之外,没关系。
关于sql - Oracle SQL 中的 OR 条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52702198/
我是一名优秀的程序员,十分优秀!