暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 在两个计算字段上选择查询,一个取决于其他计算字段

askTom 2018-02-16
314

问题描述

选择
A,
B,
A B AS C,
情况C (我不想再次使用A B这里的冗长查询)
------
-----
------
结尾为D
从表上

所以这里C是一个计算字段,我想用C的结果来计算其他字段D。我怎么能做到这一点而没有性能问题。

专家解答

内联视图可以解决问题:

SQL> create table t ( a int, b int, c int, d int );

Table created.

SQL>
SQL> insert into t values (1,2,3,4);

1 row created.

SQL>
SQL> select
  2    a,
  3    b,
  4    c,
  5    a+b-c+d/2+10-sqrt(c) as ugh
  6  from t;

         A          B          C        UGH
---------- ---------- ---------- ----------
         1          2          3 10.2679492

1 row selected.

SQL>
SQL> select
  2    a,
  3    b,
  4    c,
  5    ugh,
  6    case when ugh > 0 then 'Y' else 'N' end more_stuff
  7  from
  8    (
  9        select
 10          a,
 11          b,
 12          c,
 13          a+b-c+d/2+10-sqrt(c) as ugh
 14  from t
 15  );

         A          B          C        UGH M
---------- ---------- ---------- ---------- -
         1          2          3 10.2679492 Y

1 row selected.


「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论