繁体   English   中英

SQL-如何为没有左联接的情况下选择表的条件

[英]SQL - How to put a condition for which table is selected without left join

我在表中有一个标志,该标志的值(美国为1,全球为2)指示该数据将在表A或表B中。

一种可行的解决方案是保留两个表的连接。 但是,这会大大降低脚本的速度(从不到一秒到超过15秒)。

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

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

非常感谢您的帮助。

基本结构是:

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(?)上的索引。

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

您可以尝试使用这种方法:

-- 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上是否具有索引。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM