执行以下查询后,我从两个目录“catalogA”和“catalogB”查询中获取所有产品的 UNION:
SELECT uniontable.PK, uniontable.creationtime AS TIMECREATED FROM
(
{{
SELECT {p:mode},{p:brandno},{creationtime} AS creationtime FROM {Product AS p JOIN catalogversion AS cv ON
{p:catalogversion}={cv:pk} JOIN catalog AS cat ON {p:catalog}={cat:pk}}
WHERE {p.code} = '145' AND {cv:version}='Staged' AND {cat:id}='catalogA'
}}
UNION ALL
{{
SELECT {p:mode},{p:brandno},{creationtime} AS creationtime FROM {Product AS p JOIN catalogversion AS cv ON
{p:catalogversion}={cv:pk} JOIN catalog AS cat ON {p:catalog}={cat:pk}}
WHERE {p.code} = '123' AND {cv:version}='Staged' AND {cat:id}='catalogB'
}}
) uniontable ORDERR BY TIMECREATED
我只需要来自 UNION 查询的 CatalogA 中的产品,所以我做了如下子查询,但它会引发错误。任何帮助,将不胜感激?
查询 2:
SELECT uniontable.PK, uniontable.creationtime AS TIMECREATED FROM {Product AS p JOIN catalogversion AS cv ON
{p:catalogversion}={cv:pk} JOIN catalog AS cat ON {p:catalog}={cat:pk}}
WHERE {cv:version}='Staged' AND {cat:id}='catalogA' IN
(
{{
SELECT {p:mode},{p:brandno},{creationtime} AS creationtime FROM {Product AS p JOIN catalogversion AS cv ON
{p:catalogversion}={cv:pk} JOIN catalog AS cat ON {p:catalog}={cat:pk}}
WHERE {p.code} = '145' AND {cv:version}='Staged' AND {cat:id}='catalogA'
}}
UNION ALL
{{
SELECT {p:mode},{p:brandno},{creationtime} AS creationtime FROM {Product AS p JOIN catalogversion AS cv ON
{p:catalogversion}={cv:pk} JOIN catalog AS cat ON {p:catalog}={cat:pk}}
WHERE {p.code} = '123' AND {cv:version}='Staged' AND {cat:id}='catalogB'
}}
) uniontable ORDERR BY TIMECREATED