suchen

Heim  >  Fragen und Antworten  >  Hauptteil

MySQL - 24 aufeinanderfolgende SQL-Anweisungen, einzeln prüfen, ist es besser, alle zu vereinen?

Diese 24 aufeinanderfolgenden Linien sind ähnlich, aber die Bedingungen sind unterschiedlich, z. B. 9 Uhr bis 10 Uhr, 10 Uhr bis 11 Uhr

滿天的星座滿天的星座2812 Tage vor942

Antworte allen(3)Ich werde antworten

  • 欧阳克

    欧阳克2017-06-08 11:05:29

    “显然,使用 UNION ALL 的时候,只是单纯的把各个查询组合到一起而不会去判断数据是否重复。因此,当确定查询结果中不会有重复数据或者不需要去掉重复数据的时候,应当使用 UNION ALL 以提高查询效率。”

    Antwort
    0
  • 学习ing

    学习ing2017-06-08 11:05:29

    为什么不用OR来连接这些条件呢?比如:

    SELECT ... WHERE hour BETWEEN (9, 11) OR hour BETWEEN (13, 15)

    Antwort
    0
  • 为情所困

    为情所困2017-06-08 11:05:29

    对数据库来说24次请求肯定比一次要更消耗资源(多次验证解析+网络传输),并且如果你的时间是连续的话可以合并,最差的情况时间不连续union all更好,当然前提是时间字段有索引,不建议换成or,因为or会增加解析且当时间范围过多时会有全表扫描风险,而union all只需要将结果集合并即可

    Antwort
    0
  • StornierenAntwort