如图:
- TableA 表中有三个字段:name 字段的值是含义,value 字段的值是标记,code 字段是用来区分数据类别的
- TableB表中有两个字段:remark 和 status 都是标记,对应 TableA 表的 value 字段
- 现在要求把 TableB 表里的这两个字段的含义查出来(只查一次)。
这是我应那奇葩要求写的 sql,当然,是失败
SELECT
b.name AS remarkString,
b.name AS statusString
FROM
TableA a
INNER JOIN
TableB b
ON
(b.code = 1 AND a.remark = b.value)
OR
(b.code = 2 AND a.status = b.value)
这个是可以,但不符合要求,查询次数 n 多
SELECT
(SELECT name FROM TableB b WHERE b.code = 1 AND a.remark = b.value) AS remarkString,
(SELECT name FROM TableB b WHERE b.code = 2 AND a.status = b.value) AS statusString
FROM
TableA a