将结果从左连接转换为数组(或json或whatelse)

时间:2011-12-28 14:09:01

标签: php mysql

我实际上有这些表:

- 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?

谢谢你, 凯文

3 个答案:

答案 0 :(得分:3)

您是否反对使用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 |

此外,这是我在应用此逻辑时发现的qeustion:mySql - creating a join using a list of comma separated values

答案 1 :(得分:2)

请参阅GROUP_CONCAT()

可以找到示例here

您的查询类似于:

SELECT games.*, GROUP_CONCAT(DISTINCT ean) AS ean_array
FROM games
LEFT JOIN ean ON (games.ID = ean.ID_games)
GROUP BY games.ID

答案 2 :(得分:1)

试试这个:

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;