在纯 Oracle SQL 中选择所有行作为一个表类型对象

Posted

技术标签:

【中文标题】在纯 Oracle SQL 中选择所有行作为一个表类型对象【英文标题】:Select all rows as one table type object in pure Oracle SQL 【发布时间】:2018-10-01 07:28:40 【问题描述】:

我有以下表格类型:

CREATE OR REPLACE TYPE tab_id AS TABLE OF NUMBER(12);

我需要从表中选择 ID 并将它们作为单个 tab_id 返回。在 PL/SQL 中我会使用 BULK COLLECT INTO,但在 纯 SQL 中我需要它。我需要查询直接返回 tab_id 对象。

我试过了:

与源代码 ( 从 DUAL 中选择 1 作为令牌 联合所有 从 DUAL 中选择 2 作为令牌 ) 从 src 中选择 tab_id(token)

但这会返回两行 tab_id 类型,第一行包含值 1,第二行包含值 2。 我需要查询只返回一行,在一个tab_id 中包含两个值。

我也尝试了以下版本但没有成功:

与源代码 ( 从双重选择 1 联合所有 从双重选择 2 ) SELECT tab_id(SELECT * FROM src) FROM DUAL——我得到了 ORA-00936 SELECT tab_id( ( SELECT * FROM src ) ) FROM DUAL -- 我得到了 ORA-01427

有没有办法将所有值选择到一个表类型中?

【问题讨论】:

youtube.com/watch?v=9oF3KZBauZY 【参考方案1】:

您可以将COLLECT 函数与CAST 一起使用。

SQL Fiddle

Oracle 11g R2 架构设置

CREATE OR REPLACE TYPE tab_id AS TABLE OF NUMBER(12);

查询 1

WITH src
AS (
    SELECT 1 AS token FROM DUAL
      UNION ALL
    SELECT 2 AS token  FROM DUAL
    )
SELECT CAST(COLLECT(token) AS tab_id)
FROM src

Results

| CAST(COLLECT(TOKEN)ASTAB_ID) |
|------------------------------|
|                          1,2 |

【讨论】:

以上是关于在纯 Oracle SQL 中选择所有行作为一个表类型对象的主要内容,如果未能解决你的问题,请参考以下文章

[Oracle]Oracle良性SQL建议

从另一个表中选择一个表的否定以及oracle的主表sql查询中的数据

ORACLE 中 SQL语句优化

Oracle SQL性能优化

列举sql优化都有哪些方式方法 博客园

Oracle SQL性能优化技巧大总结