合并多个级联选择,优先级

Merge multiple cascaded selects, with priority

提问人:root66 提问时间:9/13/2015 更新时间:9/13/2015 访问量:36

问:

我正在做级联 SELECT:

SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 3
=> If nothing found, try: SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 0
=> If nothing found, try: SELECT * FROM x WHERE a = 1 AND b = 0 AND c = 0

其中至少有一个有结果,但所有情况都可以有结果。我想合并此逻辑并仅返回一个案例,即具有最多给定 (!=0) 条件的案例。

谢谢!

MySQL 数据库

评论


答:

1赞 fthiella 9/13/2015 #1

我可以使用 UNION 查询而不是存在来回答:

SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 3

UNION ALL

SELECT * FROM x
WHERE
  a = 1 AND b = 2 AND c = 0
  AND NOT EXISTS (SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 3)

UNION ALL

SELECT * FROM x
WHERE a = 1 AND b = 0 AND c = 0
  AND NOT EXISTS (SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 3)
  AND NOT EXISTS (SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 0)

但更聪明的解决方案是这样的:

SELECT * FROM x
WHERE
  (a, b, c) = (
      SELECT a, b, c
      FROM x WHERE (a, b, c) IN ( (1,2,3), (1,2,0), (1,0,0) )
      ORDER BY (b=0) + (c=0)
      LIMIT 1
  )

我不确定最后一个是否会有更好的表现。我会尝试哪一个更好。