gpt4 book ai didi

mysql - 用户有很多台计算机,计算机在不同的表中有很多属性,最好的加入方式是什么?

转载 作者:行者123 更新时间:2023-11-29 01:14:04 25 4
gpt4 key购买 nike

我有一张用户表:

USERS:
ID | NAME |
----------------
1 | JOHN |
2 | STEVE |

电脑 table :

COMPUTERS:
ID | USER_ID |
------------------
13 | 1 |
14 | 1 |

处理器表:

PROCESSORS:
ID | NAME |
---------------------------
27 | PROCESSOR TYPE 1 |
28 | PROCESSOR TYPE 2 |

和一个硬盘表:

HARDDRIVES:
ID | NAME |
---------------------------|
35 | HARDDRIVE TYPE 25 |
36 | HARDDRIVE TYPE 90 |

每台计算机都可以有许多来自不同属性表(处理器、硬盘驱动器等)的属性,所以我有这样的交集表,将属性链接到计算机:

COMPUTER_PROCESSORS:
C_ID | P_ID |
--------------|
13 | 27 |
13 | 28 |
14 | 27 |

COMPUTER_HARDDRIVES:
C_ID | H_ID |
--------------|
13 | 35 |

所以 ID 为 1 的用户 JOHN 拥有计算机 13 和 14。计算机 13 有处理器 27 和 28,计算机 13 有硬盘 35。计算机 14 有处理器 27 但没有硬盘。

给定一个用户的 ID,我想检索该用户的计算机列表以及每台计算机的属性。

我想出了一个查询,该查询给出了一些结果:

SELECT computers.id, processors.id AS p_id, processors.name AS p_name, harddrives.id AS h_id, harddrives.name AS h_name,
FROM computers

JOIN computer_processors ON (computer_processors.c_id = computers.id)
JOIN processors ON (processors.id = computer_processors.p_id)

JOIN computer_harddrives ON (computer_harddrives.c_id = computers.id)
JOIN harddrives ON (harddrives.id = computer_harddrives.h_id)

WHERE computers.user_id = 1

结果:

ID   | P_ID | P_NAME           | H_ID | H_NAME            |
-----------------------------------------------------------
13 | 27 | PROCESSOR TYPE 1 | 35 | HARDDRIVE TYPE 25 |
13 | 28 | PROCESSOR TYPE 2 | 35 | HARDDRIVE TYPE 25 |

但这有几个问题...

  1. 计算机 14 没有出现,因为它没有硬盘。我能否以某种方式进行 OUTER JOIN 以确保所有计算机都出现,即使它们没有某些属性?

  2. 计算机 13 出现了两次,两次都使用相同的硬盘列表。当更多的属性被添加到一台计算机(比如 3 个内存块)时,为该计算机返回的行数会变得相当大,这使得它不得不在应用程序代码中对结果进行排序。 我能否以某种方式进行查询,将两个返回的行组合在一起?或者在第二行的 h_name 列中返回 NULL 的查询,以便返回的所有值都是唯一的?

编辑:我想返回的是这样的:

ID   | P_ID | P_NAME           | H_ID | H_NAME            |
-----------------------------------------------------------
13 | 27 | PROCESSOR TYPE 1 | 35 | HARDDRIVE TYPE 25 |
13 | 28 | PROCESSOR TYPE 2 | 35 | NULL |
14 | 27 | PROCESSOR TYPE 1 | NULL | NULL |

或者任何可以很容易地将它变成这样的数组的结果

[13] =>
[P_NAME] =>
[0] => PROCESSOR TYPE 1
[1] => PROCESSOR TYPE 2
[H_NAME] =>
[0] => HARDDRIVE TYPE 25


[14] =>
[P_NAME] =>
[0] => PROCESSOR TYPE 1

最佳答案

使用 LEFT JOIN 而不是 INNER JOIN。这两个联接彼此不同。 INNER JOIN(您当前正在使用)仅返回在表的任一侧至少有一个匹配项的记录。这就是为什么 computer 14 不应该,因为它在表 COMPUTER_HARDDRIVES 上没有匹配项。另一方面,LEFT JOIN 返回左侧表中的所有记录,无论是否与表的另一侧匹配。

SELECT  a.ID AS UserID,
a.Name as UserName,
b.ID as ComputerID,
d.ID as ProcessorID,
d.Name as ProcessorName,
f.ID as HardDriveID,
f.name as HardDriveName
FROM users a
INNER JOIN computers b
ON a.ID = b.user_ID
LEFT JOIN computer_processors c
ON b.ID = c.C_ID
LEFT JOIN PROCESSORS d
ON c.p_ID = d.ID
LEFT JOIN COMPUTER_HARDDRIVES e
ON b.ID = e.c_ID
LEFT JOIN HARDDRIVE f
ON e.h_ID = f.ID
WHERE a.ID = 1

并且由于您想要将行组合在一起,您可以利用 GROUP_CONCAT() 函数。基本上,它所做的是将列的值组合成逗号分隔值

SELECT  a.ID AS UserID,
a.Name as UserName,
b.ID as ComputerID,
GROUP_CONCAT(DISTINCT d.ID) as ProcessorID,
GROUP_CONCAT(DISTINCT d.Name) as ProcessorName,
GROUP_CONCAT(DISTINCT f.ID) as HardDriveID,
GROUP_CONCAT(DISTINCT f.name) as HardDriveName
FROM users a
INNER JOIN computers b
ON a.ID = b.user_ID
LEFT JOIN computer_processors c
ON b.ID = c.C_ID
LEFT JOIN PROCESSORS d
ON c.p_ID = d.ID
LEFT JOIN COMPUTER_HARDDRIVES e
ON b.ID = e.c_ID
LEFT JOIN HARDDRIVE f
ON e.h_ID = f.ID
WHERE a.ID = 1
GROUP BY UserID, UserName, ComputerID

关于mysql - 用户有很多台计算机,计算机在不同的表中有很多属性,最好的加入方式是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13119250/

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