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前不能有逗号。
相关推荐
敬业小码哥21 分钟前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
练小杰1 小时前
【Mysql-installer-community-8.0.26.0】Mysql 社区版(8.0.26.0) 在Window 系统的默认安装配置
数据库·sql·mysql·adb·配置文件·mysql安装·关系型数据库
陈陈爱java2 小时前
Spring八股文
开发语言·javascript·数据库
拾忆,想起3 小时前
Redis复制延迟全解析:从毫秒到秒级的优化实战指南
java·开发语言·数据库·redis·后端·缓存·性能优化
爬山算法3 小时前
Redis(47)如何配置Redis哨兵?
数据库·redis·bootstrap
送秋三十五5 小时前
MySQL DBA需要掌握的 7 个问题
数据库·mysql·dba
jnrjian5 小时前
v$lock TS lock id1 用于发现Oracle pdb不能关闭的sid
sql·oracle
睡觉的时候不会困5 小时前
MySQL 高可用方案之 MHA 架构搭建与实践
数据库·mysql·架构
kyle~5 小时前
Qt---对话框QDialog
数据库·qt·microsoft
GBASE5 小时前
“G”术时刻:南大通用GBase 8c数据库权限管理场景实践(三)
数据库