`
overshit
  • 浏览: 33029 次
  • 性别: Icon_minigender_2
  • 来自: 上海
社区版块
存档分类
最新评论

Oracle函数sys_connect_by_path与面试题

阅读更多

 

drop table tb;
create table tb(
  year number(4),
  quarter char(1),
  amount number(2,1)
);
delete from tb;
insert into tb values(2000,1,'1.1');
insert into tb values(2000,2,'1.2');
insert into tb values(2000,3,'1.3');
insert into tb values(2000,4,'1.4');
insert into tb values(2001,1,'2.1');
insert into tb values(2001,2,'2.2');
insert into tb values(2001,3,'2.3');
insert into tb values(2001,4,'2.4');
select * from tb;

 

但要求查询的结果是:

 

select year,ltrim(max(sys_connect_by_path(amount,',')),',')amount from(
  select amount,year,row_number() over(partition by year order by amount asc)
    rn from tb) start with rn = 1 connect by rn - 1 = prior rn and year = prior year group by year;

 

 

 

 

分享到:
评论

相关推荐

    sys_connect_by_path的用法20220526.txt

    行列转换,层级关系,oracle sys_connect_by_path的用法

    ORACLE中的sys_context函数

    Oracle 中的 sys_context 函数 sys_context 函数是 Oracle 提供的一个获取环境上下文信息的预定义函数。该函数用来返回一个指定 namespace 下的 parameter 值。该函数可以在 SQL 和 PL/SQL 语言中使用。 sys_...

    oracle sys_connect_by_path 函数 结果集连接

    Oracle的`sys_connect_by_path`函数是一个非常有用的工具,尤其在构建树状结构的数据时。在本文中,我们将深入理解这个函数以及如何将其应用于非树结构的数据以生成所需的结果。 `sys_connect_by_path`函数的基本...

    connect_by_path和connect_by_root比较总结

    通过实例比较了 SYS_CONNECT_BY_PATH 和 CONNECT_BY_ROOT 的异同,和返回树形的数据结构

    Oracle的LOB(CLOB)大字段以及(SYS_LOB$$)清理.txt

    Oracle的LOB(CLOB)大字段以及(SYS_LOB$$)清理.txt

    Oracle9.2_SYS_CONTEXT函数的用法

    ### Oracle9.2_SYS_CONTEXT函数详解 在Oracle数据库系统中,`SYS_CONTEXT`函数是一个非常实用的功能,它允许用户从不同的上下文中检索信息。在Oracle9.2版本中,这个函数提供了一种灵活的方式来访问与当前会话或...

    Oracle中的USERENV和SYS_CONTEXT范例

    Oracle中的USERENV和SYS_CONTEXT是两个非常重要的函数,它们都可以用于获取当前会话的信息,例如当前用户、当前实例、当前语言等。 USERENV函数 USERENV函数用于返回当前会话的信息,例如当前用户、当前实例、当前...

    oracle函数大全(分类显示).zip_Oracle 函数分类_oracle_oracle函数分类_oracle函数查阅用文档

    Oracle数据库是世界上最流行的数据库管理系统之一,它提供了丰富的内置函数,以支持复杂的查询和数据操作。这份"oracle函数大全(分类显示).zip"压缩包显然是一份详细的Oracle函数参考手册,对于初学者而言,是一个...

    ORACLE查询树型关系(connect_by_prior_start_with)

    从 Oracle 9i 开始,可以通过 SYS_CONNECT_BY_PATH 函数实现将父节点到当前行内容以“path”或者层次元素列表的形式显示出来。 使用 START WITH 和 CONNECT BY 子句,可以 select 数据具有层次关系的数据,通常是...

    解决Oracle没有WM_CONCAT函数.zip

    SELECT REGEXP_REPLACE(SYS_CONNECT_BY_PATH(column, ','), '^,', '') AS aggregated_column FROM (SELECT column, CONNECT_BY_ROOT rowid as rid FROM table) START WITH rid = (SELECT MIN(rowid) FROM table) ...

    oracle 创建wm_concat函数

    通过以上步骤,可以在Oracle 10G及更早版本中实现与内置`wm_concat`函数类似的功能。这种方法不仅可以帮助我们在早期版本的Oracle数据库中实现字符串连接功能,还可以加深我们对Oracle数据库内部机制的理解。

    Oracle_instant_client_10_2

    path变量后边增加 C:\Oracle_instant_client_10_2; 2、在oracle安装路径(C:\oracle\product\10.2.0\db_1\network\ADMIN)中找tnsnames.ora 复制到C:\Oracle_instant_client_10_2路径下 3、第一次启动plsql,点击取消...

    Oracle百分比分析函数RATIO_TO_REPORT() OVER()实例详解

    Oracle数据库中的RATIO_TO_REPORT()函数是一个非常有用的分析函数,尤其在进行数据比例分析和比较时。这个函数能够计算一个值相对于所有值总和的比例,返回的结果是一个百分比。配合OVER()子句,它可以用于全局或者...

    ORACLE SYS.DBMS_REGISTRY_SYS has errors

    标题中的问题“ORACLE SYS.DBMS_REGISTRY_SYS has errors”指的是在Oracle数据库系统中,系统包BODY `SYS.DBMS_REGISTRY_SYS` 出现错误,导致了一系列的PL/SQL调用失败。这种错误通常与数据库的元数据注册功能有关,...

    oracle connect by level 应用

    `CONNECT BY`还可以结合`SYS_CONNECT_BY_PATH`函数,用于返回从起始节点到当前节点的路径。例如,我们可以添加一个路径列来显示每个员工的晋升路径: ```sql SELECT EMPLOYEE_NAME, MANAGER_NAME, SYS_...

    Oracle_VM_VirtualBox_Extension_Pack-5.0.2-102096扩展包

    Oracle_VM_VirtualBox_Extension_Pack-5.0.2-102096扩展包

    Oracle_hierarchical_SQL_查询应用

    自Oracle 9i版本开始,`SYS_CONNECT_BY_PATH`函数被引入,用于追踪从根节点到当前行的完整路径。在SQL1.3中,这个函数将每个地区的完整路径以斜线分隔的形式返回。例如,路径`/Asia/China/Beijing`表示从亚洲开始,...

    is_number(oracle函数判断字段是否合法数字).sql

    is_number(oracle函数判断字段是否合法数字)

    weblogic.jdbc.wrapper.Clob_oracle_sql_CLOB 类型转换解决办法

    这是因为 WebLogic 服务器为了更好地管理和操作数据库连接,会使用自己的包装类 `weblogic.jdbc.wrapper.Clob_oracle_sql_CLOB` 来表示 CLOB 类型的数据,而不是直接使用 Oracle 提供的标准 `oracle.sql.CLOB` 类。...

Global site tag (gtag.js) - Google Analytics