当前位置: 首页 > 面试题库 >

使用SQL在Oracle中创建动态列

郎子平
2023-03-14
问题内容

我有以下表格示例。Thera可以是无限的分支机构和客户。我需要对该分支进行分组并计算他们的客户,然后用不同的列来显示它。

BRANCHNAME  CUSTOMERNO
100         1001010
100         1001011
103         1001012
104         1001013
104         1001014
104         1001015
105         1001016
105         1001017
106         1001018

请注意,可以有无限的分支和客户,查询不仅必须在这种情况下有效。

在这种情况下,可接受的结果是:

100 103 104 105 106
 2   1   3   2   1

示例SQL DATA

    select '100' BranchName,'1001010' CustomerNo from dual   UNION ALL 
    select '100' BranchName,'1001011' CustomerNo from dual   UNION ALL 
    select '103' BranchName,'1001012' CustomerNo from dual   UNION ALL 
    select '104' BranchName,'1001013' CustomerNo from dual   UNION ALL 
    select '104' BranchName,'1001014' CustomerNo from dual   UNION ALL 
    select '104' BranchName,'1001015' CustomerNo from dual   UNION ALL 
    select '105' BranchName,'1001016' CustomerNo from dual   UNION ALL 
    select '105' BranchName,'1001017' CustomerNo from dual   UNION ALL 
    select '106' BranchName,'1001018' CustomerNo from dual

问题答案:

我认为写一个返回变量结构的流水线表函数虽然很复杂,但却是可能的。您的管道表函数将使用Oracle
Data Cartridge接口和AnyDataSet类型的魔力在运行时返回动态结构。然后,您可以在后续的SQL语句中使用它,就像它是一个表一样,即

SELECT *
  FROM TABLE( your_pipelined_function( p_1, p_2 ));

还有更多参考文献讨论了相同的示例实现

  • 动态SQL透视
  • 《Oracle数据盒带开发人员指南》的“实现接口方法”部分
  • 方法4。 下载并安装开源PL / SQL代码后,这里是一个完整的实现:

    --Create sample table.
    

    create table branch_data as
    select ‘100’ BranchName,‘1001010’ CustomerNo from dual UNION ALL
    select ‘100’ BranchName,‘1001011’ CustomerNo from dual UNION ALL
    select ‘103’ BranchName,‘1001012’ CustomerNo from dual UNION ALL
    select ‘104’ BranchName,‘1001013’ CustomerNo from dual UNION ALL
    select ‘104’ BranchName,‘1001014’ CustomerNo from dual UNION ALL
    select ‘104’ BranchName,‘1001015’ CustomerNo from dual UNION ALL
    select ‘105’ BranchName,‘1001016’ CustomerNo from dual UNION ALL
    select ‘105’ BranchName,‘1001017’ CustomerNo from dual UNION ALL
    select ‘106’ BranchName,‘1001018’ CustomerNo from dual;

    –Create a dynamic pivot in SQL.
    select * from table(method4.dynamic_query(
    q’[
    –Create a select statement
    select
    –The SELECT:
    ‘select’||chr(10)||
    –The column list:
    listagg(
    replace(q’!sum(case when BranchName = ‘#BRANCH_NAME#’ then 1 else 0 end) “#BRANCH_NAME#”!’, ‘#BRANCH_NAME#’, BranchName)
    , ‘,’||chr(10)) within group (order by BranchName)||chr(10)||
    –The FROM:
    ‘from branch_data’ v_sql
    from
    (
    –Distinct BranchNames.
    select distinct BranchName
    from branch_data
    )
    ]’
    ));



 类似资料:
  • 问题内容: 我有以下查询,该查询返回,商店编号及其区域以及2016年商店销售额的总和。 我将如何添加第四列,以总结每个商店所在区域的销售额。 每个区域有许多存储,因此,在相同区域中具有存储的每个ROW上,该值将相同。 希望我能解释清楚吗? 问题答案: 您可以使用窗口功能:

  • 我试图创建一个简单的表,但它给了我一个错误: 剧本: 我想不出这个问题,有人能帮忙吗?

  • 问题内容: 我的Flask路线中有一半需要使用变量或。如何创建到这些位置的链接? 需要一个参数传递给函数,但是我不能添加参数? 问题答案: 它使用关键字参数作为变量:

  • 问题内容: 我想使用变量名创建备份SQL表。 类似于 但是我越来越 ‘@SQLTable’附近的语法不正确。 这只是用于维护的小脚本的一部分,因此我不必担心注射。 问题答案:

  • 问题内容: 我有3张桌子。团队,选项,选项团队。 团队拥有一个TeamId,名称 拥有Option拥有OptionId,OptionGroup OptionTeam拥有TeamId,OptionId,OptionGroup 我想获得一个团队列表,以及额外的列,这些列指示每个组有多少个选项连接到每个团队。这是通过上面的查询完成的,但是我想用表Option中的OptionGroup值替换4,5,6,1

  • 问题内容: 对于我的应用程序,我需要在运行时进行动态数据库连接。我知道,有多种方法可以创建多个数据源,但我认为它们并不是那么动态。设想: 用户可以输入数据库凭据并连接到远程数据库,以将单个行和表导入另一个数据库。为此,我需要动态连接到远程数据库。 我试图在服务中做到这一点,就像他们在“如果在grails中使用groovy sql类”中 所说的那样,它是否使用grails连接池? 注意:在这种情况下