欧阳-95 2018-06-06 10:03 采纳率: 60%
浏览 1009
已采纳

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条回答 默认 最新

  • 六月大雪纷飞 2018-06-06 10:21
    关注

    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;

    图片说明

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么