我知道这很复杂,但我真诚地希望有人能检查一下。我制作了简短版(以便更好地理解问题)和完整版(使用原始 SQL)
精简版:
[TABLE A] [TABLE B]
|1|a|b| |1|x
|2|c|d| |1|y
|3| | | |2|z
|5| | | |2|v
|4|w
我怎样才能使 MySQL 查询得到这样的行:
1|a|b|x|y
2|c|d|z|v
来自 A 的 2 列和来自 B 的 2 行作为列,只有键 1 和 2,没有空结果
子查询?
完整版本:
我试图连续从 Prestashop db 获取:
- 产品编号
- ean13 代码
- 上行代码
- ID 为 24 的功能
- id 为 25 的功能
获取 id_product、ean13 和 upc 很容易,因为它是 ps_product 表中的一行。为了获得我使用子查询的功能(JOIN 没有成功)。
因此,我选择了 id_product, ean13, upc, (subquery1) 作为 code1, (subquery2) 作为 code2。然后我需要扔掉空行。但不能只将 code1 或 code2 放在 WHERE 中。为了让它工作,我必须把所有东西都放在子查询中。
这段代码可以工作,但它非常难看,我敢打赌这应该以不同的方式完成。
我怎样才能让它变得更好?
SELECT * FROM(
SELECT
p.id_product as idp, p.ean13 as ean13, p.upc as upc, (
SELECT
fvl.value
FROM
`ps_feature_product` fp
LEFT JOIN
`ps_feature_value_lang` fvl ON (fp.id_feature_value = fvl.id_feature_value)
WHERE fp.id_feature = 24 AND fp.id_product = idp
) AS code1, (
SELECT
fvl.value
FROM
`ps_feature_product` fp
LEFT JOIN
`ps_feature_value_lang` fvl ON (fp.id_feature_value = fvl.id_feature_value)
WHERE fp.id_feature = 25 AND fp.id_product = idp
) AS code2,
m.name
FROM
`ps_product` p
LEFT JOIN
`ps_manufacturer` m ON (p.id_manufacturer = m.id_manufacturer)
) mainq
WHERE
ean13 != '' OR upc != '' OR code1 IS NOT NULL OR code2 IS NOT NULL