【问题标题】:Multiple SQL queries on one table一张表上的多个 SQL 查询
【发布时间】:2012-12-04 01:49:53
【问题描述】:

我正在使用 LAMP。在 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% 确定。我是在重新发明轮子吗?

非常感谢...

【问题讨论】:

  • 您真的需要中间集(B、C 和 D),还是只关心 E 集?
  • 嗨,Ripta,是的,我确实需要中间集。

标签: mysql sql join


【解决方案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)

希望对你有帮助

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多