首页 > 解决方案 > MySQL SELECT 在 SELECT 子句或 WHERE 子句中,以便进一步过滤

问题描述

我正在尝试过滤一些数据,但是由于数据来自数据库中的 2 个表,我必须将它们合并在一起,允许来自第二个表的空值,因为我总是需要在第一个表中提供任何值,因为这个是一个产品数据库,其中一些产品具有子组合,而另一些则没有。到目前为止,我已经想出了使用 Union 将两个表连接在一起,但现在我需要一种方法来使用 WHERE 子句过滤掉数据;但是:这是我卡住的地方。我尝试将联合作为 FROM 子句中的选择语句:没有返回数据,我尝试将其作为子句放入 SELECT 子句中:没有返回数据......

简而言之,我需要这样的东西:

SELECT id_product, id_product_attribute,upc1,upc2 
FROM (UNION) 
WHERE upc1='xyz' OR upc2='xyz';

例如,结果可能是这样的:

-> 100, null, 9912456, null

或者

-> 200, 153, 9915559, 9977123

目前我有这个(对不起,我没有更多):

(SELECT     product.id_product as id_product, 
            product.upc as upc1, 
            comb.id_product_attribute, 
            comb.upc as upc2
 FROM   `db`.table1 product
   LEFT JOIN `db`.table2 comb
   ON comb.id_product = product.id_product
)
UNION
(SELECT     product.id_product as id_product, 
            product.upc as headCNK, 
            comb.id_product_attribute, 
            comb.upc
 FROM   `db`.table1 product
   RIGHT JOIN `db`.table2 comb
   ON comb.id_product = product.id_product
);

另请注意,upc1 来自表 1,而 upc2 来自表 2。

我可以使用整个查询,并在最坏的情况下使用一些业务逻辑过滤掉所有内容,但不是因为我不想在不需要的地方执行无休止的查询,我的服务提供商不喜欢那样...

更新: 我也试过:

SELECT * 
from db.t1 as prod 
CROSS JOIN db.t2 as comb ON prod.id_product = comb.id_product 
WHERE prod.upc = 'xyz' OR comb.upc = 'xyz'; 

这也不起作用。


在这里放了一些小样本数据的小提琴: http ://sqlfiddle.com/#!9/340d7d

查询SELECT id_product、id_product_attribute、table1.upc、table2.upc中 where 子句中使用的“991002”的输出应为:101、null、991002、null

对于“990001”,它应该是:101、201、990001、990001

标签: mysqlselectunion

解决方案


对于所有值尝试

SELECT t1.id_product, t2.id_product_attribute, t1.upc, t2.upc
FROM ( SELECT upc FROM table1
       UNION 
       SELECT upc FROM table2 ) t0
LEFT JOIN table1 t1 USING (upc)
LEFT JOIN table2 t2 USING (upc)

对于确定upc值编辑

...
SELECT t1.id_product, t2.id_product_attribute, t1.upc, t2.upc
FROM ( SELECT 990001 upc ) t0
LEFT JOIN table1 t1 USING (upc)
LEFT JOIN table2 t2 USING (upc)
...

推荐阅读