oracle将select作为字段查询

在Oracle中,如果你想将一个SELECT语句作为字段的值,你可以使用子查询或者使用WITH子句(也称为公用表表达式CTE)。以下是两种方法的示例:

方法1:使用子查询

语法如下:

sql 复制代码
SELECT
    column1,
    (SELECT COUNT(*) FROM another_table WHERE another_table.column2 = table1.column1) AS count_value
FROM
    table1;
  

实例:

sql 复制代码
SELECT
(SELECT a.companycname
          FROM ggcompany a
         WHERE a.companycode = SUBSTR(mm.companycode, 0, 4)) 二级机构,
       (SELECT a.companycname
          FROM ggcompany a
         WHERE a.companycode = SUBSTR(mm.companycode, 0, 6)) 三级机构,
       (SELECT a.companycname
       
          FROM ggcompany a
         WHERE a.companycode = mm.companycode) 四级机构,
       mm.policyno 保单号
       from gppolicyplandetail mm

方法2:使用WITH子句(CTE)

语法:

sql 复制代码
WITH count_cte AS (
    SELECT column2, COUNT(*) AS count_value
    FROM another_table
    GROUP BY column2
)
SELECT
    t1.column1,
    count_cte.count_value
FROM
    table1 t1
    LEFT JOIN count_cte ON count_cte.column2 = t1.column1;

解释:count_cte 是中间表,命名随意,要是需要多个中间表,可以用逗号连接。

实例:

sql 复制代码
WITH
          w AS (
                    SELECT
                              statdate          ,
                              classname         ,
                              riskname          ,
                              cityname          ,
                              policyno          ,
                              registno          ,
                              claimno           ,
                              damagedate        ,
                              reportdate        ,
                              claimdate         ,
                              underwriteenddate ,
                              endcasedate       ,
                              rgstcncldate      ,
                              canceldate        ,
                              firstestloss      ,
                              unsettledpaidbegin,
                              unsettledpaidend  ,
                              settled           ,
                              sumpaid           ,
                              reportlossfee     ,
                              canceldateloss
                    FROM
                              r_lsts_jsreportlist
                    WHERE
                              statdate = DATE '2022-03-31'
          )     ,
          ff AS (
                    SELECT
                              statdate          ,
                              classname         ,
                              riskname          ,
                              cityname          ,
                              policyno          ,
                              registno          ,
                              claimno           ,
                              damagedate        ,
                              reportdate        ,
                              claimdate         ,
                              underwriteenddate ,
                              endcasedate       ,
                              rgstcncldate      ,
                              canceldate        ,
                              firstestloss      ,
                              unsettledpaidbegin,
                              unsettledpaidend  ,
                              settled           ,
                              sumpaid           ,
                              reportlossfee     ,
                              canceldateloss
                    FROM
                              r_lsts_jsreportlist
                    WHERE
                              statdate = DATE '2024-09-30'
          )
SELECT
          ff.statdate 统计日期,
          ff.classname 险类 ,
          ff.riskname 险种  ,
          ff.cityname 机构  ,
          w.settled
FROM
          ff
          LEFT JOIN w ON ff.riskname = w.riskname AND
          ff.policyno = w.policyno AND
          ff.registno = w.registno AND
          ff.claimno = w.claimno
复制代码
         解释:W和FF都是临时表,中间用逗号隔开,中间结束需要有select ,select前不能有逗号。
相关推荐
better_liang1 分钟前
每日Java面试场景题知识点之-数据库与缓存的一致性
java·数据库·redis·面试·分布式系统·缓存一致性·cache aside
light blue bird5 分钟前
工序路径主子表单工序组装图表组件
前端·数据库·信息可视化·.net·web端·razor page
我叫张小白。6 分钟前
基于Redis与FastAPI的分布式共享会话体系
数据库·redis·分布式·缓存·中间件·fastapi·依赖注入
java_cj8 分钟前
MySQL 8.0新特性详解:从隐藏索引到窗口函数全面解析
数据库·mysql·架构·开源
数据库安全8 分钟前
业务可用、数据可控:美创“动态脱敏+数据库透明加密“合规方案
数据库
Wonderful U12 分钟前
AI智能日志异常检测告警平台:告别人工排查,秒级定位线上故障
数据库·人工智能·python·django
天河归来14 分钟前
国产数据库安全可靠测评产品观察:从集中式、分布式到 HTAP 的发展趋势
数据库·分布式
rising start21 分钟前
Redis 哨兵模式(Sentinel)
数据库·redis·sentinel
DarkAthena28 分钟前
【ORACLE】添加短信以外的双因素认证方式
oracle
梦幻通灵33 分钟前
Mysql处理锁冲突Lock conflict可用方案
数据库·mysql