mysql - 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
解决方案
对于所有值尝试
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)
...
推荐阅读
- php - 为类别自定义 Wordpress 日期存档小部件
- bash - 如何从 shell 脚本或命令行为 github(企业/组织帐户)生成个人访问令牌?
- postgresql - 将字符变化 [] 转换为字符变化 postgresql
- php - PHP无法使用Cpanel找到库
- c# - 具有动态 where 条件的 Linq 子选择
- java - 为什么 Firebase 新更新中的服务 FirebaseInstanceIdService 会丢失?
- android - 参数类型不得包含类型变量或通配符
- php - 在 IIS 上安装 Web 项目
- jquery - 根据单选按钮选择隐藏或显示值
- jquery - JQuery slim 包与主库冲突。: $(...).scrollTo 不是一个函数?