【问题标题】:Need to combine multiple rows in MySql or Access with one row需要在MySql或Access中将多行合并为一行
【发布时间】:2012-04-08 22:26:00
【问题描述】:

我有一个包含 sku 编号、attribute_name 和属性值的表。每个 sku 都可以有许多属性。

现在表格看起来像这样。

SKU、ATT_NM、ATT_VAL TOST3580,供应型,碳粉 TOST3580,消费前回收含量百分比 [标称],0 % TOST3580,消费后回收含量百分比 [标称],0 % TOST3580,总回收含量百分比 [标称],0 % TOST3580, OEM/兼容, OEM

我需要他们更像这样。

SKU,ATT_NM,ATT_VAL,ATT_NM1,ATT_VAL1 TOST3580,Supply,Type,Toner,Pre-Consumer Recycled Content Percent,0 %

添加每个属性值。因此,例如上面的示例将具有 5 个不同的属性。每个 SKU 都有 2-20 个属性。任何帮助都是极好的。抱歉格式不好。

这可以在 Access 或 MySQL 中完成

【问题讨论】:

  • 1) 我不太明白结果。你丢失了数据。 EG:OEM/Compatible 去哪儿了? 2) 你的意思是你想为每个sku 添加所有att_nm 连接?
  • 您可能应该将 ATT_NM 文本内容移动到另一个表,然后在此表中使用 ATT_ID 链接到它。
  • 是的,对于每个 SKU,我想将所有 ATT_NM 和 ATT_VAL 添加到一行中。

标签: mysql ms-access ms-access-2007


【解决方案1】:

你可以尝试这样的事情(使用 MySQL)-

SELECT
    SKU,
    GROUP_CONCAT(IF(ATT_NM = 'Supply Type', ATT_VAL, NULL)) AS `Supply Type`,
    GROUP_CONCAT(IF(ATT_NM = 'Pre-Consumer Recycled Content Percent [Nom]', ATT_VAL, NULL)) AS `Pre-Consumer Recycled Content Percent [Nom]`,
    ...
FROM table
GROUP BY SKU

您可以使用 -

检索属性列表
SELECT DISTINCT ATT_NM
FROM table

然后使用返回的值构建上一个查询。

【讨论】:

    猜你喜欢
    • 2014-02-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-06-09
    • 2012-08-29
    • 2015-04-20
    • 2010-11-07
    • 1970-01-01
    相关资源
    最近更新 更多