簡體   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