示例:如果以下查询
Select * from emp;
获取30条记录.. 输出为:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
7499 ALLEN SALESMAN 7698 20-FEB-81 1600 300 30
7521 WARD SALESMAN 7698 22-FEB-81 1250 500 30
.....(more 28 records)........
每条记录都应保存在一个单独的文件中,文件名为' Empno.Ename'
答案 0 :(得分:1)
您需要执行以下操作
将每条记录中的数据保存在自己的文件中并关闭文件
DECLARE
file_name VARCHAR2(30) := NULL;
out_file UTL_FILE.file_type;
dir_path VARCHAR2(100) := NULL; -- Give the directory alias, where you want to store file
BEGIN
FOR record IN
(
SELECT *
FROM emp
)
LOOP
file_name := TO_CHAR(record.empno) || '.' || TO_CHAR(record.ename);
out_file := UTL_FILE.fopen (i_chr_dir_path, file_name, 'W', 32767);
UTL_FILE.put_line(out_file, record.empno || ',' || record.ename || ',' || record.job
-- more fields
);
IF UTL_FILE.is_open (out_file) THEN
UTL_FILE.fclose (out_file);
END IF;
END LOOP;
END;
答案 1 :(得分:1)
以下是其中一个选项。您只需为表中的每一行生成一个带有select语句的文件,然后执行它。
这里有一个名为T1
的表,其中包含7条记录。该文件(让我们将其命名为tabletofiles.sql
)如下所示:
set feedback off;
set termout off;
set heading off;
set verify off;
set sqlblanklines on;
# temp file with statements
spool /tmp/tmpfile.sql
# specify column names you want to fetch explicitly
select 'spool /tmp/file_' || to_char(rownum) || ';' || chr(10) ||
'select c1
from (select q.*
, rownum as rn
from &1 q )
where rn = ' || to_number(rownum) || ';' ||
chr(10) || 'spool off;'
from &1;
spool off;
@@tmpfile.sql
#clean up after ourselfs
!rm -I /tmp/tmpfile.sql
将表名作为参数传递
SQL> @/tmp/tabletofiles.sql t1
执行完成后,tmpfile.sql
包含以下内容:
spool /tmp/file_1;
select c1
from (select q.*
, rownum as rn
from t1 q )
where rn = 1;
spool off;
spool /tmp/file_2;
select c1
from (select q.*
, rownum as rn
from t1 q )
where rn = 2;
spool off;
...
每个select
语句的结果假脱机到另一个文件中。
以下是我们的最终文件:
82 Jun 26 11:28 file_1.lst
82 Jun 26 11:28 file_2.lst
82 Jun 26 11:28 file_3.lst
82 Jun 26 11:28 file_4.lst
82 Jun 26 11:28 file_5.lst
82 Jun 26 11:28 file_6.lst
82 Jun 26 11:28 file_7.lst
答案 2 :(得分:1)
假设:
emp
记录的所有数据都驻留在一行上(例如,数据中没有嵌入的回车符,数据不会跨越多行)emp.raw
awk
是一个有效选项(OP标有linux
,unix
和ksh
)示例emp.raw的内容:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
7499 ALLEN SALESMAN 7698 20-FEB-81 1600 300 30
7521 WARD SALESMAN 7698 22-FEB-81 1250 500 30
1行awk
解决方案:
$ awk '!/^EMPNO/ { print > $1"."$2}' emp.raw
结果:
$ ls -1
7499.ALLEN
7521.WARD
emp.raw
$ for f in 7*
> do
> echo "+++++++++++++ $f"
> cat $f
> done
+++++++++++++ 7499.ALLEN
7499 ALLEN SALESMAN 7698 20-FEB-81 1600 300 30
+++++++++++++ 7521.WARD
7521 WARD SALESMAN 7698 22-FEB-81 1250 500 30