0

我正在使用灯。在 MySql 中,我有一个包含 X、Y 和 Z 列的表。我需要从多个集合和子集中选择不同的记录。如果我的初始标准是 WHERE Y = A; 那么我需要能够:

  • 通过选择 Y = A 的记录来获取集合 B,
  • 通过选择 X 在集合 B 中且 Z = 123 的记录来获取集合 C
  • 通过选择 Y 在集合 B 中且 Z = 456 的记录来获取集合 D
  • 通过选择 X 在集合 D 和 Z = 789 中的记录来获取集合 E

桌子可能会变得很大,我不确定从哪里开始。一些可能的方法是:

  1. 有多个单独的查询。在这种情况下,我将如何缓存一个查询的结果集以用作另一个查询的输入?内存缓存?
  2. 使用嵌套子查询。但是内部查询的结果纯粹是为了限制外部查询,不是吗?我如何让它们出现在结果中?
  3. 使用联合。但是我将如何存储一个查询的结果以用作另一个查询的输入?
  4. 多次将表加入到自身中。这将产生一个笛卡尔结果,其中外部行重复多次。这将映射到应该是可管理的多维 PHP 数组。但是性能呢?

我倾向于选项 4,但不是 100% 肯定。我在重新发明轮子吗?

非常感激...

4

1 回答 1

1

我不明白您的目标,因为您没有定义对 X 的限制,但是根据您的描述,我相信集合 E 将是空的。我这样说是因为集合 D 已经包含 Z 为 456 的行。因此,当您对该结果集运行另一个查询以针对 Z 为 789 的条件生成 E 时,您将不会得到任何行,因为 D 中的所有行都是 456。

现在发表个人意见:

  1. 尽可能避免笛卡尔积 - 连接很好,但要小心,尽可能避免交叉积
  2. 如果需要,对表进行非规范化以提高查询效率
  3. 生成能够产生最小结果集的查询以满足您的要求
  4. 如果可能的话,使用子查询来减少结果集的大小
  5. 信任查询优化器,尽可能避免子查询
  6. 尽可能让 SQL 完成工作,因为它有能力和资源以最佳方式计算数据

为了突出上面的第 4 项,我想提一下,在您的 D 示例中,您可以编写以下查询而无需子查询或任何其他临时存储:

SELECT * FROM MyTable WHERE Y = A AND Z = 456

现在,也许我可以通过猜测你想要什么来尝试解决你的困境:

SELECT * FROM MyTable WHERE Y = A AND Z IN (123, 456, 789)

或者:

SELECT * FROM MyTable WHERE Y = A AND (Z = 123 OR Z = 456 OR Z = 789)

希望这可以帮助

于 2012-12-17T01:29:38.903 回答