加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何在oracle中为记录类型编写循环

发布时间:2020-12-12 15:14:28 所属栏目:百科 来源:网络整理
导读:我有以下声明在我的包中编译好: 包头: TYPE role_user_type IS RECORD ( ROLE_ID some_table.ROLE_ID%TYPE,SUBGROUP some_table.USER_ID%TYPE ); 身体: ROLE_USER_REC MY_PACKAGE.ROLE_USER_TYPE;SELECT B.USER_ID,B.ROLE INTO ROLE_USER_RECFROM some_ta
我有以下声明在我的包中编译好:

包头:

TYPE role_user_type IS RECORD (
      ROLE_ID        some_table.ROLE_ID%TYPE,SUBGROUP       some_table.USER_ID%TYPE
   );

身体:

ROLE_USER_REC                  MY_PACKAGE.ROLE_USER_TYPE;

SELECT B.USER_ID,B.ROLE INTO ROLE_USER_REC
FROM some_table where user_id like 'M%'

循环通过ROLE_USER_REC的骨架是什么?我们甚至可以通过它吗?

没有什么可循环的.

role_user_type定义了一条记录,您可以通过以下方式访问:

dbms_output.put_line( role_user_rec.role_id || ',' || role_user_rec.subgroup );

只要返回多行,SELECT … INTO就会失败.

如果您需要存储其中几条记录,可以使用nested tables之类的
TYPE role_user_tab IS TABLE of role_user_type:

例:

DECLARE
  TYPE role_user_type IS RECORD (
     ROLE_ID        VARCHAR2(10),SUBGROUP       VARCHAR2(10)
  );
  TYPE role_user_tab IS TABLE OF role_user_type;
  role_user_rec role_user_tab;
BEGIN
  SELECT 'A','B'
  BULK COLLECT INTO role_user_rec
  FROM dual;
  FOR i IN role_user_rec.FIRST .. role_user_rec.LAST LOOP
    dbms_output.put_line( role_user_rec(i).role_id || ',' || role_user_rec(i).subgroup );
  END LOOP;
END;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读