gpt4 book ai didi

php - 如何从一个表中获取 2 列和 2 行作为一行中其他表的列,在 MySQL 中?

转载 作者:可可西里 更新时间:2023-11-01 08:33:39 25 4
gpt4 key购买 nike

我知道这很复杂,但我真诚地希望有人能检查一下。我制作了简短版(以便更好地理解问题)和完整版(使用原始 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代码
  • upc代码
  • 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

最佳答案

create table tablea 
( id int,
col1 varchar(1),
col2 varchar(1));

create table tableb
( id int,
feature int,
cola varchar(1));

insert into tablea (id, col1, col2)
select 1,'a','b' union
select 2,'c','d' union
select 3,null,null union
select 5,null,null;


insert into tableb (id, feature, cola)
select 1,24,'x' union
select 1,25,'y' union
select 2,24,'z' union
select 2,25,'v' union
select 4,24,'w';

select a.id, a.col1, a.col2, b1.cola b1a, b2.cola b2a
from tablea a
inner join tableb b1 on (b1.id = a.id and b1.feature = 24)
inner join tableb b2 on (b2.id = a.id and b2.feature = 25);

SQLFiddle here .

关于php - 如何从一个表中获取 2 列和 2 行作为一行中其他表的列,在 MySQL 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19275864/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com