select
a.* , 0 flag
from tableA a where member not in ( select member from tableB)
union all
select
a.* , 1 flag
from tableA a where member in ( select member from tableB)
SELECT a.*, 0 flag
FROM tableA a
WHERE NOT EXISTS(
SELECT 1 FROM tableB b WHERE (a.member=b.member))
union all
SELECT a.*, 1 flag
FROM tableA a
WHERE EXISTS(
SELECT 1 FROM tableB b WHERE (a.member=b.member))
2条答案
按热度按时间rqmkfv5c1#
请使用以下命令:
7d7tgy0s2#
不 是 一 个 很 好 的 解决 方案 , 但 你 可以 试试 这个 。
所以 , 我们 用 not in 或 not exists 得到 一 组 数据 , 然后 用 in 或 exists 得到 另 一 组 数据 , 然后 把 它们 合并 在 一起 得到 完整 的 数据 集 。
中 的 每 一 个
诀窍 可能 是 , 您 可以 为此 运行 2 个 单独 的 SQL , 并 将 获得 perf 的 好处 , 而 不是 union all 。
不 存在 将 以 相同 的 方式 工作 , 但 可以 给 你 更 好 的 性能 。
格式