- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一张用户表:
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 |
但这有几个问题...
计算机 14 没有出现,因为它没有硬盘。我能否以某种方式进行 OUTER JOIN 以确保所有计算机都出现,即使它们没有某些属性?
计算机 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/
有没有办法在不进行提交/ check out 的情况下应用差异补丁或类似补丁? 我的情况:我工作时经常在计算机之间切换,我的提交历史记录有一堆“switching machines”消息。 我最初的猜
我的自定义引导加载程序中有代码从地址 0x8E00 处的 512 字节缓冲区复制内存。进入高内存,0x100000和更高。这在某些计算机上运行良好,而在其他计算机上崩溃(我假设是三重故障)。此代码在
服务器有没有办法将一些数据无线无缝地推送到客户端,可能是 Windows(电话)、iPhone、Mac 或 Android 设备,没有任何操作系统集成? 如果是这样,最好的设计模式是什么,最好的技术是
我无法理解hadoop的真正本质。 如果我有足够的资源来购买可以处理PB级数据的 super 计算机,那么为什么我需要Hadoop基础架构来管理如此大的数据? 最佳答案 hadoop的全部目的是能够在
我有一个奇怪的问题,或者我可能无法理解Grails i18n机制的工作原理。 我将以下内容插入到index.gsp文件中: LocaleContextHolder.locale:
我正在尝试为我的小弟弟编写一个简单的程序。他经常在他的电脑后面,但他应该为学校学习简单的算术 :D 我想制作以下程序: 他启动了他的电脑 他需要做一些简单的练习并完成 如果他做对了 x 次,他可以继续
有人能告诉我如何在 diff 主机(计算机)上为 MySQL 数据库做一个简单的数据库备份吗?我正在尝试将我的数据库从一台主机(服务器)移动到一台新主机(服务器) 最佳答案 如果您只是需要在服务器之间
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是无关紧要的,因
我正在尝试让 Android 应用程序使用 USB 电缆与运行 ubuntu 12.04 lts 的 Linux 计算机进行通信。我正在尝试使用 usbdeviceconnection 类,但是当我通
我刚刚使用 docker-toolbox 1.8.2 安装了 docker在 Windows 10 上。 由于由于this issue我不得不使用这些命令重新创建 docker 镜像 docker-m
如何删除处于 GURU_MEDITATION 错误状态的 VirtualBox 计算机?在 VirtualBox 未运行时删除该目录是否足够? 编辑:发布后,我删除了“在文件管理器中显示”导航到的整个
当我们在 Azure 机器学习服务中将模型部署为 ACIWebService 时,不需要指定任何 deployment_target。 根据AzureML documentation对于 azurem
当我们在 Azure 机器学习服务中将模型部署为 ACIWebService 时,不需要指定任何 deployment_target。 根据AzureML documentation对于 azurem
我遇到的主要问题是当我选择 stay 时会发生什么上hand_one ,然后 hit上hand_two . 而不是让我hit or stay上hand_two再次,它让我回到hit or stay上h
我知道我可以使用 putty 来 ssh 进入每台 Linux 机器并更新 CentOS 服务器...但我希望有人能够为我指明正确的方向,告诉我如何通过 PowerShell 或 Windows 中的
在 MIX 计算机中,一个单词由五个字节和一个符号组成。符号在内存中是如何表示的?是另一个字节,所以每个字真的是六个字节吗? 谢谢。 最佳答案 你的问题不是很清楚。体系结构规范未指定实际实现。它仅指定
我是 Python 的初级程序员,我的电脑有一个奇怪的问题。当我的计算机上有一个 .py 文件(包含一个有效的脚本)并双击它打开时,会发生以下情况:程序打开(它是黑屏 View ),但它会在一秒钟内自
我正在尝试在 Windows 上使用 plink 创建到 Linux 机器的隧道,并让转储文件最终出现在 Windows 机器上。看起来 this answer会工作,是我的问题的基础。但是尝试一下并
我想在 Windows 7 和 10 计算机上执行重启,但我首先需要将 Jenkins 节点暂时离线。在执行重启之前,我需要完成所有正在运行的任务。然后我远程登录到服务器并重新启动计算机。然而,在我重
我正在编写一个简单的程序,从 MySQL 数据库中提取计算机名称,然后将这些名称存储到字符串数组列表中(这部分工作正常)。之后,我编写了一个类和一个方法,将字符串作为参数(这将是计算机名称)并尝试对其
我是一名优秀的程序员,十分优秀!