RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1094316
Accepted
Александр
Александр
Asked:2020-03-13 22:28:46 +0000 UTC2020-03-13 22:28:46 +0000 UTC 2020-03-13 22:28:46 +0000 UTC

通过 OUT 参数从过程结果输出

  • 772

需要通过 OUT 参数实现程序的输出,而不使用剪贴板,即dbms_output.put_line.

该程序在包装中。

PROCEDURE array_app
    (street IN Streets.TITLE%TYPE,
    dom IN APARTMENTS.HOUSE%TYPE,
    res OUT Varchar2) 
IS
    CURSOR my_cur IS SELECT DISTINCT idapart FROM POSSESSION;
    CURSOR cur1 (street IN VARCHAR2, dom IN INTEGER)  
    IS
        SELECT APARTMENTS.id, num FROM APARTMENTS, Streets
        WHERE HOUSE = dom AND TITLE = street AND APARTMENTS.IDSTREET = Streets.ID;
    kv INTEGER;
    cnumber number;
    str Varchar2(100);
BEGIN
    res := '';
    OPEN cur1 (street, dom);
    FETCH cur1 INTO cnumber, kv;
        FOR f IN  my_cur  LOOP
            IF f.idapart = cnumber THEN
                str := res;
                select str || ', ' || kv INTO res from dual;
                RETURN;
            END IF;
        END LOOP;
    CLOSE cur1;
END;

和一个过程调用

DECLARE
   res1 Varchar2(100);
BEGIN
   pack.array_app('Татищева', 75, res1);
END;

数据示例:这是一个房屋表,其中的列分别是代码、街道和门牌号以及公寓号:

CREATE TABLE Apartments (id INTEGER PRIMARY KEY, idstreet VARCHAR2(100), house INTEGER NOT NULL, num INTEGER);

INSERT INTO Apartments (id, idstreet, house, num) VALUES (1, 'Татищева', 75, 5);
INSERT INTO Apartments (id, idstreet, house, num) VALUES (2, 'Кирова', 3, 15);
INSERT INTO Apartments (id, idstreet, house, num) VALUES (3, 'Новая', 28, 34);
INSERT INTO Apartments (id, idstreet, house, num) VALUES (4, 'Татищева', 75, 150);

还有一个所有权表,其中包含所有权对象的代码:

CREATE TABLE Possession (id INTEGER PRIMARY KEY, idapart INTEGER NOT NULL REFERENCES Apartments);

INSERT INTO Possession (id, idapart) VALUES (1, 1);
INSERT INTO Possession (id, idapart) VALUES (2, 4);

因此,结果,代码为 1 的记录被选中并返回公寓号码。如果输入数据集中有多个元素包含在两个带有数据的表中,则应返回所有相应的公寓号码。

sql
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    0xdb
    2020-03-16T01:08:30Z2020-03-16T01:08:30Z

    例如,您可以这样:

    create or replace package pack1 as
        procedure array_app (street varchar2, house integer, cur1 out sys_refcursor);
    end;
    /
    create or replace package body pack1 as
        procedure array_app (street varchar2, house integer, cur1 out sys_refcursor) is
        begin
            open cur1 for 
                select a.num 
                from apartments a
                where a.house = array_app.house 
                and a.idstreet = array_app.street
                and exists (
                    select 1 
                    from possession p 
                    where p.idapart = a.id
                );
        end array_app;
    end pack1;
    /
    

    运行和结果:

    var cur1 refcursor
    exec pack1.array_app('Татищева', 75, :cur1)
    print cur1
    
           NUM
    ----------
           150
             5
    
    • 4

相关问题

  • ON 关键字附近的语法错误 - SQL

  • 多表查询中的 Count() 聚合函数

  • 根据时间更改单元格中的日期

  • phpMyAdmin 中的错误 #1064 SQL 查询

  • Qt:包含变量的数据库查询

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5