用oracle utl_file包读取数据写入文件
create or replace directory MY_DIR as '/usr/test/';
create or replace function f_exportTxt(
--传入参数
i_query in varchar2,
i_separator in varchar2,
i_dir in varchar2,
i_filename in varchar2
) return number
is
/**
** 函数名:f_exportTxt
** 参数:1.i_query 查询sql语句; 2.i_separator 分隔符,默认为',' ;
** 3.i_dir存放目录; 4.i_filename文件名,默认在文件名前加上yyyymmddhh24mi
** 返回: 大于等于0即为写入文件记录数,负为异常
** 功能: 用户数据抽取,并生成文件到指定目录下
** 备注:
** 作者:lingo
** 修改日期:2010-04-15
**/
--定义参数
v_file utl_file.file_type;
v_theCursor integer default dbms_sql.open_cursor;
v_columnValue varchar2(2000); --临时(列值)
v_colCnt number default 0; --列总数
v_separator varchar2(10) default ',';--分隔符,默认为#@
v_cnt number default 0; --记录总数
v_filename varchar2(100);--时间
v_status integer;--执行SQL后返回状态值
v_count number default 10000 ; --每次查询的数量,大于该数量则多次读取数据到游标
v_tmp number ;--临时(总记录数,通过SQL统计算出,假如v_cnt不等于v_tmp,则导出有误)
v_sql varchar2(2000) ; --组合sql语句
v_loops number ; --循环次数
begin
--select to_char(sysdate,'yyyymmddhh24mi') into v_filename from dual; --取时间年月日时分做文件名前缀
v_filename :='';
v_filename := v_filename||i_filename ; --组建文件名
v_sql := 'select count(''x'') from (' ||i_query||')' ;--统计总数
execute immediate v_sql into v_tmp;
select trunc(v_tmp/v_count) into v_loops from dual ; --循环次数
if mod(v_tmp,v_count) > 0 then
v_loops := v_loops+1;
end if;
v_file := utl_file.fopen(i_dir,v_filename,'W'); --打开文件
for i in 1 .. v_loops loop
v_sql := 'select * from ( select m.*,rownum r fr
相关文档:
Linux/Unix上,Oracle是多个进程实现的,每一个主要函数都是一个进程;在Windows上,则是一个单一进程,进程中包含多个线程。
Oracle把一系列物理文件,如数据文件(Data file)、控制文件(Control file)、联机日志(Redo log file)、参数文件(spfile or pfile)等物理结构及与之对应的逻辑结构,如表空间(Tablespace)、段(Seg ......
玩Oracle也有2年的时间了, 零零散散的也整理一些资料。 东西一多了,就理不清楚。 所以结合张晓明的《大话Oracle RAC》的一些内容,和自己整理的一些笔记,对Oracle 的备份和恢复做了一个系统的整理。 也是自己对知识的一个巩固吧。
一. 准备知识
先来看一些准备知识,了解 ......
添加引用
using System.Data.OracleClient;
主要用到了两个类
System.Data.OracleClient.OracleConnection 表示一个到数据库的连接。此类无法继承。
System.Data.OracleClient.OracleCommand 表示针对数据库执行的 SQL 语句或存 ......
正常来说,在完成Select语句、create index等一些使用TEMP表空间的排序操作后,Oracle是会自动释放掉临时段a的。但有些有侯我们则会遇到临时段没有被释放,TEMP表空间几乎满的状况,甚至是我们重启了数据库仍没有解决问题。这个问题在论坛中也常被网友问到,下面我总结一下,给出几种处理方法。
......
--定义类型
CREATE OR REPLACE TYPE ty_str_split IS TABLE OF VARCHAR2(4000);
--创建函数
CREATE OR REPLACE FUNCTION f_stringsplit (p_str IN VARCHAR2, p_delimiter IN VARCHAR2)
RETURN ty_str_split PIPELINED
/*****
****字符串拆分,相当于java.lang.String类的split方法
****注意:新增t ......