我实际上有这些表:
- Table games -
ID
Name
- Table ean -
ID
ID_games
EAN
我有这个请求:
SELECT games.*, ean.EAN
FROM games
LEFT JOIN ean ON (games.ID = ean.ID_games)
结果将是这样的:
| 1 | Half Life | 358958595 |
| 1 | Half Life | 589584859 |
| 2 | Half Life 2 | 385953684 |
| 2 | Half Life 2 | 585100335 |
etc.
当我做我的请求并在php中使用它时,有很多行大约相同的结果是没有用的。我想这样做:
SELECT games.*, ConvertToArray(ean) AS ean_array
FROM games
LEFT JOIN ean ON (games.ID = ean.ID_games)
得到这样的结果:
| 1 | Half Life | (358958595,589584859) |
| 2 | Half Life 2 | (385953684,585100335 ) |
etc.
这是可能的mysql ?没有UDF ?和UDF ?
谢谢你,凯文
您是否反对使用GROUP_CONCAT
?这将为您提供一个漂亮的分隔符列表(假设ean
值中永远不会包含分隔符):
SELECT games.*, GROUP_CONCAT(ean.EAN) AS ean_list,
FROM games
LEFT JOIN ean
ON games.ID = ean.ID_games
GROUP BY games.ID, games.name
导致:
| 1 | Half Life | 358958595,589584859 |
| 2 | Half Life 2 | 385953684,585100335 |
此外,这里有一个问题,我发现这个逻辑应用:mySql -创建一个连接使用逗号分隔值列表
参见GROUP_CONCAT()。
示例可以在这里找到。
你的查询看起来像这样:
SELECT games.*, GROUP_CONCAT(DISTINCT ean) AS ean_array
FROM games
LEFT JOIN ean ON (games.ID = ean.ID_games)
GROUP BY games.ID
试试这个:
SELECT g.id, GROUP_CONCAT(CAST(e.ean AS CHAR) SEPARATOR ', ')
FROM games g
LEFT JOIN ean e ON g.id = e.id_games
GROUP BY g.id;