首页 > 数据库 > Oracle > 正文

数据库人员手册之输出Oracle对象源码

2024-08-29 13:50:00
字体:
来源:转载
供稿:网友
  Oracle数据库数据对象中最基本的是表和视图,其他还有约束、序列、函数、存储过程、包、触发器等。对数据库的操作可以基本归结为对数据对象的操作,理解和把握Oracle数据库对象是学习Oracle的捷径。      way 1:
      通过spool输出到文件:set serveroutput on
spool 'c:/log.txt'DECLARE
    v_text VARCHAR2(1000);
    --i number(3):=0;
    CURSOR cur IS
        SELECT text
          FROM sys.DBA_SOURCE
         WHERE OWNER = 'SCOTT'
           AND NAME = 'TESTCCB';
BEGIN
    OPEN cur;
    LOOP
        FETCH cur
            INTO v_text;
        --DBMS_OUTPUT.PUT_LINE(' cityname = ' v_name' count=' i);
        DBMS_OUTPUT.put_line(v_text);
        --i :=  i+ 1;
        EXIT WHEN cur%NOTFOUND;
   
    END LOOP;    CLOSE cur;
END;
/
spool off
 
      way2:
      利用 utl_file 包直接写出到文件
      要求oracle用户对os文件系统有操作权限DECLARE
    v_text   VARCHAR2(1000);
    v_dir    VARCHAR2(256);
    v_owner  VARCHAR2(128);
    v_obj    VARCHAR2(128);
    l_output utl_file.file_type;
    CURSOR cur IS
        SELECT text
          FROM dba_source
         WHERE OWNER = v_owner
           AND NAME = v_obj;
BEGIN
    v_owner := 'SCOTT';
    v_obj   := 'EMP';
    SELECT t.Directory_path INTO v_dir FROM all_directories t;
    l_output := utl_file.fopen(v_dir, 'tab.txt', 'w');
    utl_file.new_line(l_output);
    utl_file.put_line(l_output,
                      '-- output owner :' v_owner '  object: '
                      v_obj);    OPEN cur;

    LOOP
        FETCH cur
            INTO v_text;
        EXIT WHEN cur%NOTFOUND;
        utl_file.new_line(l_output);
        utl_file.put_line(l_output, v_text);
    END LOOP;
    utl_file.new_line(l_output);
    utl_file.put_line(l_output, '-- output finished! ');    utl_file.fclose(l_output);
    CLOSE cur;
END;
/


上一篇:数据库人员手册之ORACLE应用源码

下一篇:双机容错环境Oracle数据库应用

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表
学习交流
热门图片

新闻热点

疑难解答

图片精选

网友关注