SQL - 如何为没有左连接而选择哪个表的条件

时间:2018-03-07 11:06:24

标签: sql sql-server dbeaver

我在表格中有一个标志,其值(美国为1,全局为2)表示数据是否在表A或表B中。

一个有效的解决方案是将两个表连接起来;然而,这会大大减慢脚本的速度(从不到一秒钟到超过15秒)。

还有其他聪明的方法吗?相当于

 join TableA only if TableCore.CountryFlag = "US"
 join TableB only if TableCore.CountryFlag = "global"

非常感谢你的帮助。

2 个答案:

答案 0 :(得分:0)

基本结构是:

select . . ., coalesce(a.?, b.?) as ?
from tablecore c left join
     tablea a
     on c.? = a.? and c.countryflag = 'US' left join
     tableb b
     on c.? b.? and c.counryflag = 'global';

此版本的查询可以利用tablea(?)tableb(?)上的索引。

如果您有复杂的查询,则此部分可能不会对性能问题负责。

答案 1 :(得分:0)

您可以尝试使用此方法:

-- US data
SELECT
    YourColumns
FROM
    TableCore
    INNER JOIN TableA AS T ON TableCore.JoinColumn = T.JoinColumn
WHERE
    TableCore.CountryFlag = 'US'

UNION ALL

-- Non-US Data
SELECT
    YourColumns -- These columns must match in number and datatype with previous SELECT
FROM
    TableCore
    INNER JOIN TableB AS T ON TableCore.JoinColumn = T.JoinColumn
WHERE
    TableCore.CountryFlag = 'global'

但是,如果结果仍然很慢,您可能想要检查TableCore表是否在CountryFlag和JoinColumn上有索引,而TableA和TableB是否在JoinColumn上有索引。