SQL - 如何在没有左连接的情况下放置选择 table 的条件
SQL - How to put a condition for which table is selected without left join
我在 table 中有一个标志,其值(美国为 1,全球为 2)表示数据将在 Table A 或 Table B 中。
一个可行的解决方案是左连接两个 table;然而,这会显着降低脚本速度(从不到一秒到超过 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 table 是否在 CountryFlag 和 JoinColumn 上有索引,以及 TableA 和 TableB 在 JoinColumn 上是否有索引。
我在 table 中有一个标志,其值(美国为 1,全球为 2)表示数据将在 Table A 或 Table B 中。
一个可行的解决方案是左连接两个 table;然而,这会显着降低脚本速度(从不到一秒到超过 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 table 是否在 CountryFlag 和 JoinColumn 上有索引,以及 TableA 和 TableB 在 JoinColumn 上是否有索引。