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前不能有逗号。
相关推荐
云淡风轻~窗明几净几秒前
ubuntu的lazarus的Tline/TeaLine组件的构思
linux·数据库·ubuntu
雒珣1 分钟前
Qt实现命令行参数功能示例:QCommandLineParser
开发语言·数据库·qt
知识分享小能手7 分钟前
MongoDB入门学习教程,从入门到精通,MongoDB备份完全指南(23)
数据库·学习·mongodb
源来猿往11 分钟前
mysql转postgresql【平移】
数据库·mysql·postgresql
爱学习的小囧14 分钟前
VMFS与NFS性能对比(含场景适配+实操建议)
运维·数据库·自动化·esxi·虚拟化
byte轻骑兵16 分钟前
Apache IoTDB 技术特性与大数据时序数据库选型实践
大数据·数据库·人工智能·物联网·时序数据库
Dream of maid17 分钟前
Mysql(7)子查询
android·数据库·mysql
学习中的DGR20 分钟前
[极客大挑战 2019]BabySQL 1新手解题过程
数据库·web安全·网络安全
大黄说说35 分钟前
Go并发双雄:WaitGroup与Channel的抉择与协作
java·服务器·数据库
喜欢打篮球的普通人42 分钟前
MLIR入门
数据库·mlir