Oracle 的复杂奇葩查询要求,求围观!!!!

如图:

  • 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

3个回答

SELECT
a.name AS remarkString,
b.name AS statusString
FROM (select name,value from A,B where A.code = 1 and B.remark=A.value) a,(select name,value from A,B where A.code = 2 and B.status
=A.value) b where a.value=b.value;

图片说明

不知道你是不是想达到这种效果。

qq_40574584
六月下起了大雪 我的A是你的TABLE A,B是你的TABLE B
接近 2 年之前 回复

SELECT
a.name AS remarkString,
aa.name AS statusString
FROM
TableB b
left join TableA a on a.value=b.remark and a.code=1
left join TableA aa on aa.value=b.status and aa.code=2

请采纳,谢谢

qq_31165105
欧阳-95 大佬,抱歉,楼上有人提供了类似的方法。。。。。
接近 2 年之前 回复

都没描述清楚,你tableB中又没有code 段,怎么一一对应。。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐